@mihcm/ui 0.14.1
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/README.md +138 -0
- package/dist/AccessLevelGroup.d.ts +37 -0
- package/dist/AccessLevelGroup.d.ts.map +1 -0
- package/dist/AccessLevelGroup.js +39 -0
- package/dist/AccessLevelGroup.js.map +1 -0
- package/dist/AccessLevelGroup.native.d.ts +18 -0
- package/dist/AccessLevelGroup.native.d.ts.map +1 -0
- package/dist/AccessLevelGroup.native.js +40 -0
- package/dist/AccessLevelGroup.native.js.map +1 -0
- package/dist/Accordion.d.ts +52 -0
- package/dist/Accordion.d.ts.map +1 -0
- package/dist/Accordion.js +90 -0
- package/dist/Accordion.js.map +1 -0
- package/dist/Accordion.native.d.ts +36 -0
- package/dist/Accordion.native.d.ts.map +1 -0
- package/dist/Accordion.native.js +86 -0
- package/dist/Accordion.native.js.map +1 -0
- package/dist/Alert.d.ts +33 -0
- package/dist/Alert.d.ts.map +1 -0
- package/dist/Alert.js +45 -0
- package/dist/Alert.js.map +1 -0
- package/dist/Alert.native.d.ts +26 -0
- package/dist/Alert.native.d.ts.map +1 -0
- package/dist/Alert.native.js +41 -0
- package/dist/Alert.native.js.map +1 -0
- package/dist/AlertDialog.d.ts +57 -0
- package/dist/AlertDialog.d.ts.map +1 -0
- package/dist/AlertDialog.js +91 -0
- package/dist/AlertDialog.js.map +1 -0
- package/dist/AlertDialog.native.d.ts +66 -0
- package/dist/AlertDialog.native.d.ts.map +1 -0
- package/dist/AlertDialog.native.js +71 -0
- package/dist/AlertDialog.native.js.map +1 -0
- package/dist/AspectRatio.d.ts +18 -0
- package/dist/AspectRatio.d.ts.map +1 -0
- package/dist/AspectRatio.js +19 -0
- package/dist/AspectRatio.js.map +1 -0
- package/dist/AspectRatio.native.d.ts +7 -0
- package/dist/AspectRatio.native.d.ts.map +1 -0
- package/dist/AspectRatio.native.js +13 -0
- package/dist/AspectRatio.native.js.map +1 -0
- package/dist/Avatar.d.ts +45 -0
- package/dist/Avatar.d.ts.map +1 -0
- package/dist/Avatar.js +69 -0
- package/dist/Avatar.js.map +1 -0
- package/dist/Avatar.native.d.ts +38 -0
- package/dist/Avatar.native.d.ts.map +1 -0
- package/dist/Avatar.native.js +56 -0
- package/dist/Avatar.native.js.map +1 -0
- package/dist/AvatarGroup.d.ts +32 -0
- package/dist/AvatarGroup.d.ts.map +1 -0
- package/dist/AvatarGroup.js +45 -0
- package/dist/AvatarGroup.js.map +1 -0
- package/dist/AvatarGroup.native.d.ts +18 -0
- package/dist/AvatarGroup.native.d.ts.map +1 -0
- package/dist/AvatarGroup.native.js +35 -0
- package/dist/AvatarGroup.native.js.map +1 -0
- package/dist/Badge.d.ts +26 -0
- package/dist/Badge.d.ts.map +1 -0
- package/dist/Badge.js +44 -0
- package/dist/Badge.js.map +1 -0
- package/dist/Badge.native.d.ts +23 -0
- package/dist/Badge.native.d.ts.map +1 -0
- package/dist/Badge.native.js +49 -0
- package/dist/Badge.native.js.map +1 -0
- package/dist/Banner.d.ts +27 -0
- package/dist/Banner.d.ts.map +1 -0
- package/dist/Banner.js +41 -0
- package/dist/Banner.js.map +1 -0
- package/dist/Banner.native.d.ts +24 -0
- package/dist/Banner.native.d.ts.map +1 -0
- package/dist/Banner.native.js +39 -0
- package/dist/Banner.native.js.map +1 -0
- package/dist/BarList.d.ts +27 -0
- package/dist/BarList.d.ts.map +1 -0
- package/dist/BarList.js +25 -0
- package/dist/BarList.js.map +1 -0
- package/dist/Breadcrumb.d.ts +67 -0
- package/dist/Breadcrumb.d.ts.map +1 -0
- package/dist/Breadcrumb.js +63 -0
- package/dist/Breadcrumb.js.map +1 -0
- package/dist/Breadcrumb.native.d.ts +64 -0
- package/dist/Breadcrumb.native.d.ts.map +1 -0
- package/dist/Breadcrumb.native.js +50 -0
- package/dist/Breadcrumb.native.js.map +1 -0
- package/dist/Button.d.ts +42 -0
- package/dist/Button.d.ts.map +1 -0
- package/dist/Button.js +68 -0
- package/dist/Button.js.map +1 -0
- package/dist/Button.native.d.ts +38 -0
- package/dist/Button.native.d.ts.map +1 -0
- package/dist/Button.native.js +51 -0
- package/dist/Button.native.js.map +1 -0
- package/dist/Calendar.d.ts +16 -0
- package/dist/Calendar.d.ts.map +1 -0
- package/dist/Calendar.js +94 -0
- package/dist/Calendar.js.map +1 -0
- package/dist/Calendar.native.d.ts +21 -0
- package/dist/Calendar.native.d.ts.map +1 -0
- package/dist/Calendar.native.js +15 -0
- package/dist/Calendar.native.js.map +1 -0
- package/dist/Card.d.ts +29 -0
- package/dist/Card.d.ts.map +1 -0
- package/dist/Card.js +44 -0
- package/dist/Card.js.map +1 -0
- package/dist/Card.native.d.ts +20 -0
- package/dist/Card.native.d.ts.map +1 -0
- package/dist/Card.native.js +32 -0
- package/dist/Card.native.js.map +1 -0
- package/dist/Carousel.d.ts +46 -0
- package/dist/Carousel.d.ts.map +1 -0
- package/dist/Carousel.js +115 -0
- package/dist/Carousel.js.map +1 -0
- package/dist/Carousel.native.d.ts +59 -0
- package/dist/Carousel.native.d.ts.map +1 -0
- package/dist/Carousel.native.js +93 -0
- package/dist/Carousel.native.js.map +1 -0
- package/dist/CategoryBar.d.ts +22 -0
- package/dist/CategoryBar.d.ts.map +1 -0
- package/dist/CategoryBar.js +27 -0
- package/dist/CategoryBar.js.map +1 -0
- package/dist/Chart.d.ts +77 -0
- package/dist/Chart.d.ts.map +1 -0
- package/dist/Chart.js +197 -0
- package/dist/Chart.js.map +1 -0
- package/dist/Checkbox.d.ts +28 -0
- package/dist/Checkbox.d.ts.map +1 -0
- package/dist/Checkbox.js +44 -0
- package/dist/Checkbox.js.map +1 -0
- package/dist/Checkbox.native.d.ts +13 -0
- package/dist/Checkbox.native.d.ts.map +1 -0
- package/dist/Checkbox.native.js +34 -0
- package/dist/Checkbox.native.js.map +1 -0
- package/dist/CheckboxGrid.d.ts +49 -0
- package/dist/CheckboxGrid.d.ts.map +1 -0
- package/dist/CheckboxGrid.js +79 -0
- package/dist/CheckboxGrid.js.map +1 -0
- package/dist/CheckboxGrid.native.d.ts +14 -0
- package/dist/CheckboxGrid.native.d.ts.map +1 -0
- package/dist/CheckboxGrid.native.js +47 -0
- package/dist/CheckboxGrid.native.js.map +1 -0
- package/dist/Collapsible.d.ts +51 -0
- package/dist/Collapsible.d.ts.map +1 -0
- package/dist/Collapsible.js +101 -0
- package/dist/Collapsible.js.map +1 -0
- package/dist/Collapsible.native.d.ts +53 -0
- package/dist/Collapsible.native.d.ts.map +1 -0
- package/dist/Collapsible.native.js +109 -0
- package/dist/Collapsible.native.js.map +1 -0
- package/dist/Combobox.d.ts +42 -0
- package/dist/Combobox.d.ts.map +1 -0
- package/dist/Combobox.js +96 -0
- package/dist/Combobox.js.map +1 -0
- package/dist/Combobox.native.d.ts +21 -0
- package/dist/Combobox.native.d.ts.map +1 -0
- package/dist/Combobox.native.js +28 -0
- package/dist/Combobox.native.js.map +1 -0
- package/dist/Command.d.ts +107 -0
- package/dist/Command.d.ts.map +1 -0
- package/dist/Command.js +68 -0
- package/dist/Command.js.map +1 -0
- package/dist/Command.native.d.ts +41 -0
- package/dist/Command.native.d.ts.map +1 -0
- package/dist/Command.native.js +31 -0
- package/dist/Command.native.js.map +1 -0
- package/dist/ContextMenu.d.ts +48 -0
- package/dist/ContextMenu.d.ts.map +1 -0
- package/dist/ContextMenu.js +79 -0
- package/dist/ContextMenu.js.map +1 -0
- package/dist/ContextMenu.native.d.ts +81 -0
- package/dist/ContextMenu.native.d.ts.map +1 -0
- package/dist/ContextMenu.native.js +82 -0
- package/dist/ContextMenu.native.js.map +1 -0
- package/dist/DataTable.d.ts +98 -0
- package/dist/DataTable.d.ts.map +1 -0
- package/dist/DataTable.js +291 -0
- package/dist/DataTable.js.map +1 -0
- package/dist/DataTable.native.d.ts +31 -0
- package/dist/DataTable.native.d.ts.map +1 -0
- package/dist/DataTable.native.js +22 -0
- package/dist/DataTable.native.js.map +1 -0
- package/dist/DatePicker.d.ts +63 -0
- package/dist/DatePicker.d.ts.map +1 -0
- package/dist/DatePicker.js +106 -0
- package/dist/DatePicker.js.map +1 -0
- package/dist/DatePicker.native.d.ts +21 -0
- package/dist/DatePicker.native.d.ts.map +1 -0
- package/dist/DatePicker.native.js +15 -0
- package/dist/DatePicker.native.js.map +1 -0
- package/dist/Dialog.d.ts +52 -0
- package/dist/Dialog.d.ts.map +1 -0
- package/dist/Dialog.js +93 -0
- package/dist/Dialog.js.map +1 -0
- package/dist/Dialog.native.d.ts +57 -0
- package/dist/Dialog.native.d.ts.map +1 -0
- package/dist/Dialog.native.js +62 -0
- package/dist/Dialog.native.js.map +1 -0
- package/dist/Drawer.d.ts +36 -0
- package/dist/Drawer.d.ts.map +1 -0
- package/dist/Drawer.js +57 -0
- package/dist/Drawer.js.map +1 -0
- package/dist/Drawer.native.d.ts +50 -0
- package/dist/Drawer.native.d.ts.map +1 -0
- package/dist/Drawer.native.js +43 -0
- package/dist/Drawer.native.js.map +1 -0
- package/dist/DropdownMenu.d.ts +57 -0
- package/dist/DropdownMenu.d.ts.map +1 -0
- package/dist/DropdownMenu.js +192 -0
- package/dist/DropdownMenu.js.map +1 -0
- package/dist/DropdownMenu.native.d.ts +53 -0
- package/dist/DropdownMenu.native.d.ts.map +1 -0
- package/dist/DropdownMenu.native.js +71 -0
- package/dist/DropdownMenu.native.js.map +1 -0
- package/dist/Dropzone.d.ts +27 -0
- package/dist/Dropzone.d.ts.map +1 -0
- package/dist/Dropzone.js +33 -0
- package/dist/Dropzone.js.map +1 -0
- package/dist/EmptyState.d.ts +21 -0
- package/dist/EmptyState.d.ts.map +1 -0
- package/dist/EmptyState.js +16 -0
- package/dist/EmptyState.js.map +1 -0
- package/dist/EmptyState.native.d.ts +19 -0
- package/dist/EmptyState.native.d.ts.map +1 -0
- package/dist/EmptyState.native.js +16 -0
- package/dist/EmptyState.native.js.map +1 -0
- package/dist/Form.d.ts +310 -0
- package/dist/Form.d.ts.map +1 -0
- package/dist/Form.js +260 -0
- package/dist/Form.js.map +1 -0
- package/dist/Form.native.d.ts +36 -0
- package/dist/Form.native.d.ts.map +1 -0
- package/dist/Form.native.js +33 -0
- package/dist/Form.native.js.map +1 -0
- package/dist/HoverCard.d.ts +47 -0
- package/dist/HoverCard.d.ts.map +1 -0
- package/dist/HoverCard.js +86 -0
- package/dist/HoverCard.js.map +1 -0
- package/dist/HoverCard.native.d.ts +48 -0
- package/dist/HoverCard.native.d.ts.map +1 -0
- package/dist/HoverCard.native.js +19 -0
- package/dist/HoverCard.native.js.map +1 -0
- package/dist/IconSidebar.d.ts +50 -0
- package/dist/IconSidebar.d.ts.map +1 -0
- package/dist/IconSidebar.js +121 -0
- package/dist/IconSidebar.js.map +1 -0
- package/dist/IconSidebar.native.d.ts +40 -0
- package/dist/IconSidebar.native.d.ts.map +1 -0
- package/dist/IconSidebar.native.js +24 -0
- package/dist/IconSidebar.native.js.map +1 -0
- package/dist/Input.d.ts +52 -0
- package/dist/Input.d.ts.map +1 -0
- package/dist/Input.js +57 -0
- package/dist/Input.js.map +1 -0
- package/dist/Input.native.d.ts +37 -0
- package/dist/Input.native.d.ts.map +1 -0
- package/dist/Input.native.js +39 -0
- package/dist/Input.native.js.map +1 -0
- package/dist/InputOTP.d.ts +30 -0
- package/dist/InputOTP.d.ts.map +1 -0
- package/dist/InputOTP.js +47 -0
- package/dist/InputOTP.js.map +1 -0
- package/dist/InputOTP.native.d.ts +32 -0
- package/dist/InputOTP.native.d.ts.map +1 -0
- package/dist/InputOTP.native.js +48 -0
- package/dist/InputOTP.native.js.map +1 -0
- package/dist/Label.d.ts +26 -0
- package/dist/Label.d.ts.map +1 -0
- package/dist/Label.js +35 -0
- package/dist/Label.js.map +1 -0
- package/dist/Label.native.d.ts +26 -0
- package/dist/Label.native.d.ts.map +1 -0
- package/dist/Label.native.js +30 -0
- package/dist/Label.native.js.map +1 -0
- package/dist/Link.d.ts +21 -0
- package/dist/Link.d.ts.map +1 -0
- package/dist/Link.js +46 -0
- package/dist/Link.js.map +1 -0
- package/dist/Link.native.d.ts +23 -0
- package/dist/Link.native.d.ts.map +1 -0
- package/dist/Link.native.js +59 -0
- package/dist/Link.native.js.map +1 -0
- package/dist/Logo.d.ts +25 -0
- package/dist/Logo.d.ts.map +1 -0
- package/dist/Logo.js +58 -0
- package/dist/Logo.js.map +1 -0
- package/dist/Logo.native.d.ts +22 -0
- package/dist/Logo.native.d.ts.map +1 -0
- package/dist/Logo.native.js +46 -0
- package/dist/Logo.native.js.map +1 -0
- package/dist/MainSidebar.d.ts +2 -0
- package/dist/MainSidebar.d.ts.map +1 -0
- package/dist/MainSidebar.js +3 -0
- package/dist/MainSidebar.js.map +1 -0
- package/dist/MainSidebar.native.d.ts +2 -0
- package/dist/MainSidebar.native.d.ts.map +1 -0
- package/dist/MainSidebar.native.js +2 -0
- package/dist/MainSidebar.native.js.map +1 -0
- package/dist/Menubar.d.ts +70 -0
- package/dist/Menubar.d.ts.map +1 -0
- package/dist/Menubar.js +142 -0
- package/dist/Menubar.js.map +1 -0
- package/dist/NavigationMenu.d.ts +12 -0
- package/dist/NavigationMenu.d.ts.map +1 -0
- package/dist/NavigationMenu.js +63 -0
- package/dist/NavigationMenu.js.map +1 -0
- package/dist/NavigationMenu.native.d.ts +44 -0
- package/dist/NavigationMenu.native.d.ts.map +1 -0
- package/dist/NavigationMenu.native.js +43 -0
- package/dist/NavigationMenu.native.js.map +1 -0
- package/dist/NotificationBadge.d.ts +33 -0
- package/dist/NotificationBadge.d.ts.map +1 -0
- package/dist/NotificationBadge.js +49 -0
- package/dist/NotificationBadge.js.map +1 -0
- package/dist/NotificationBadge.native.d.ts +25 -0
- package/dist/NotificationBadge.native.d.ts.map +1 -0
- package/dist/NotificationBadge.native.js +41 -0
- package/dist/NotificationBadge.native.js.map +1 -0
- package/dist/PageShell.d.ts +24 -0
- package/dist/PageShell.d.ts.map +1 -0
- package/dist/PageShell.js +24 -0
- package/dist/PageShell.js.map +1 -0
- package/dist/PageShell.native.d.ts +21 -0
- package/dist/PageShell.native.d.ts.map +1 -0
- package/dist/PageShell.native.js +19 -0
- package/dist/PageShell.native.js.map +1 -0
- package/dist/Pagination.d.ts +53 -0
- package/dist/Pagination.d.ts.map +1 -0
- package/dist/Pagination.js +79 -0
- package/dist/Pagination.js.map +1 -0
- package/dist/Pagination.native.d.ts +48 -0
- package/dist/Pagination.native.d.ts.map +1 -0
- package/dist/Pagination.native.js +55 -0
- package/dist/Pagination.native.js.map +1 -0
- package/dist/Popover.d.ts +57 -0
- package/dist/Popover.d.ts.map +1 -0
- package/dist/Popover.js +71 -0
- package/dist/Popover.js.map +1 -0
- package/dist/Popover.native.d.ts +48 -0
- package/dist/Popover.native.d.ts.map +1 -0
- package/dist/Popover.native.js +65 -0
- package/dist/Popover.native.js.map +1 -0
- package/dist/Popper.d.ts +54 -0
- package/dist/Popper.d.ts.map +1 -0
- package/dist/Popper.js +219 -0
- package/dist/Popper.js.map +1 -0
- package/dist/Progress.d.ts +79 -0
- package/dist/Progress.d.ts.map +1 -0
- package/dist/Progress.js +110 -0
- package/dist/Progress.js.map +1 -0
- package/dist/Progress.native.d.ts +42 -0
- package/dist/Progress.native.d.ts.map +1 -0
- package/dist/Progress.native.js +91 -0
- package/dist/Progress.native.js.map +1 -0
- package/dist/ProgressCircle.d.ts +69 -0
- package/dist/ProgressCircle.d.ts.map +1 -0
- package/dist/ProgressCircle.js +78 -0
- package/dist/ProgressCircle.js.map +1 -0
- package/dist/RadioCardGroup.d.ts +26 -0
- package/dist/RadioCardGroup.d.ts.map +1 -0
- package/dist/RadioCardGroup.js +26 -0
- package/dist/RadioCardGroup.js.map +1 -0
- package/dist/RadioGroup.d.ts +35 -0
- package/dist/RadioGroup.d.ts.map +1 -0
- package/dist/RadioGroup.js +68 -0
- package/dist/RadioGroup.js.map +1 -0
- package/dist/RadioGroup.native.d.ts +33 -0
- package/dist/RadioGroup.native.d.ts.map +1 -0
- package/dist/RadioGroup.native.js +55 -0
- package/dist/RadioGroup.native.js.map +1 -0
- package/dist/Resizable.d.ts +32 -0
- package/dist/Resizable.d.ts.map +1 -0
- package/dist/Resizable.js +31 -0
- package/dist/Resizable.js.map +1 -0
- package/dist/Resizable.native.d.ts +32 -0
- package/dist/Resizable.native.d.ts.map +1 -0
- package/dist/Resizable.native.js +23 -0
- package/dist/Resizable.native.js.map +1 -0
- package/dist/RichTextEditor.d.ts +38 -0
- package/dist/RichTextEditor.d.ts.map +1 -0
- package/dist/RichTextEditor.js +218 -0
- package/dist/RichTextEditor.js.map +1 -0
- package/dist/ScrollArea.d.ts +4 -0
- package/dist/ScrollArea.d.ts.map +1 -0
- package/dist/ScrollArea.js +26 -0
- package/dist/ScrollArea.js.map +1 -0
- package/dist/ScrollArea.native.d.ts +19 -0
- package/dist/ScrollArea.native.d.ts.map +1 -0
- package/dist/ScrollArea.native.js +19 -0
- package/dist/ScrollArea.native.js.map +1 -0
- package/dist/SearchField.d.ts +43 -0
- package/dist/SearchField.d.ts.map +1 -0
- package/dist/SearchField.js +34 -0
- package/dist/SearchField.js.map +1 -0
- package/dist/SearchField.native.d.ts +31 -0
- package/dist/SearchField.native.d.ts.map +1 -0
- package/dist/SearchField.native.js +30 -0
- package/dist/SearchField.native.js.map +1 -0
- package/dist/SectionHeader.d.ts +58 -0
- package/dist/SectionHeader.d.ts.map +1 -0
- package/dist/SectionHeader.js +95 -0
- package/dist/SectionHeader.js.map +1 -0
- package/dist/SectionHeader.native.d.ts +45 -0
- package/dist/SectionHeader.native.d.ts.map +1 -0
- package/dist/SectionHeader.native.js +92 -0
- package/dist/SectionHeader.native.js.map +1 -0
- package/dist/Select.d.ts +78 -0
- package/dist/Select.d.ts.map +1 -0
- package/dist/Select.js +310 -0
- package/dist/Select.js.map +1 -0
- package/dist/Select.native.d.ts +53 -0
- package/dist/Select.native.d.ts.map +1 -0
- package/dist/Select.native.js +86 -0
- package/dist/Select.native.js.map +1 -0
- package/dist/Separator.d.ts +20 -0
- package/dist/Separator.d.ts.map +1 -0
- package/dist/Separator.js +20 -0
- package/dist/Separator.js.map +1 -0
- package/dist/Separator.native.d.ts +8 -0
- package/dist/Separator.native.d.ts.map +1 -0
- package/dist/Separator.native.js +17 -0
- package/dist/Separator.native.js.map +1 -0
- package/dist/Sheet.d.ts +54 -0
- package/dist/Sheet.d.ts.map +1 -0
- package/dist/Sheet.js +191 -0
- package/dist/Sheet.js.map +1 -0
- package/dist/Sheet.native.d.ts +55 -0
- package/dist/Sheet.native.d.ts.map +1 -0
- package/dist/Sheet.native.js +112 -0
- package/dist/Sheet.native.js.map +1 -0
- package/dist/Sidebar.d.ts +131 -0
- package/dist/Sidebar.d.ts.map +1 -0
- package/dist/Sidebar.js +328 -0
- package/dist/Sidebar.js.map +1 -0
- package/dist/Skeleton.d.ts +14 -0
- package/dist/Skeleton.d.ts.map +1 -0
- package/dist/Skeleton.js +17 -0
- package/dist/Skeleton.js.map +1 -0
- package/dist/Skeleton.native.d.ts +6 -0
- package/dist/Skeleton.native.d.ts.map +1 -0
- package/dist/Skeleton.native.js +26 -0
- package/dist/Skeleton.native.js.map +1 -0
- package/dist/Slider.d.ts +63 -0
- package/dist/Slider.d.ts.map +1 -0
- package/dist/Slider.js +109 -0
- package/dist/Slider.js.map +1 -0
- package/dist/Slider.native.d.ts +38 -0
- package/dist/Slider.native.d.ts.map +1 -0
- package/dist/Slider.native.js +18 -0
- package/dist/Slider.native.js.map +1 -0
- package/dist/SortableList.d.ts +26 -0
- package/dist/SortableList.d.ts.map +1 -0
- package/dist/SortableList.js +44 -0
- package/dist/SortableList.js.map +1 -0
- package/dist/SparkChart.d.ts +34 -0
- package/dist/SparkChart.d.ts.map +1 -0
- package/dist/SparkChart.js +55 -0
- package/dist/SparkChart.js.map +1 -0
- package/dist/StatCard.d.ts +35 -0
- package/dist/StatCard.d.ts.map +1 -0
- package/dist/StatCard.js +37 -0
- package/dist/StatCard.js.map +1 -0
- package/dist/StatCard.native.d.ts +28 -0
- package/dist/StatCard.native.d.ts.map +1 -0
- package/dist/StatCard.native.js +31 -0
- package/dist/StatCard.native.js.map +1 -0
- package/dist/StatusBadge.d.ts +23 -0
- package/dist/StatusBadge.d.ts.map +1 -0
- package/dist/StatusBadge.js +33 -0
- package/dist/StatusBadge.js.map +1 -0
- package/dist/StatusBadge.native.d.ts +21 -0
- package/dist/StatusBadge.native.d.ts.map +1 -0
- package/dist/StatusBadge.native.js +37 -0
- package/dist/StatusBadge.native.js.map +1 -0
- package/dist/Switch.d.ts +31 -0
- package/dist/Switch.d.ts.map +1 -0
- package/dist/Switch.js +46 -0
- package/dist/Switch.js.map +1 -0
- package/dist/Switch.native.d.ts +16 -0
- package/dist/Switch.native.d.ts.map +1 -0
- package/dist/Switch.native.js +41 -0
- package/dist/Switch.native.js.map +1 -0
- package/dist/TabNavigation.d.ts +49 -0
- package/dist/TabNavigation.d.ts.map +1 -0
- package/dist/TabNavigation.js +121 -0
- package/dist/TabNavigation.js.map +1 -0
- package/dist/Table.d.ts +54 -0
- package/dist/Table.d.ts.map +1 -0
- package/dist/Table.js +96 -0
- package/dist/Table.js.map +1 -0
- package/dist/Table.native.d.ts +37 -0
- package/dist/Table.native.d.ts.map +1 -0
- package/dist/Table.native.js +37 -0
- package/dist/Table.native.js.map +1 -0
- package/dist/Tabs.d.ts +45 -0
- package/dist/Tabs.d.ts.map +1 -0
- package/dist/Tabs.js +94 -0
- package/dist/Tabs.js.map +1 -0
- package/dist/Tabs.native.d.ts +47 -0
- package/dist/Tabs.native.d.ts.map +1 -0
- package/dist/Tabs.native.js +57 -0
- package/dist/Tabs.native.js.map +1 -0
- package/dist/Tag.d.ts +24 -0
- package/dist/Tag.d.ts.map +1 -0
- package/dist/Tag.js +41 -0
- package/dist/Tag.js.map +1 -0
- package/dist/Tag.native.d.ts +23 -0
- package/dist/Tag.native.d.ts.map +1 -0
- package/dist/Tag.native.js +55 -0
- package/dist/Tag.native.js.map +1 -0
- package/dist/Text.d.ts +26 -0
- package/dist/Text.d.ts.map +1 -0
- package/dist/Text.js +63 -0
- package/dist/Text.js.map +1 -0
- package/dist/Text.native.d.ts +18 -0
- package/dist/Text.native.d.ts.map +1 -0
- package/dist/Text.native.js +58 -0
- package/dist/Text.native.js.map +1 -0
- package/dist/Textarea.d.ts +23 -0
- package/dist/Textarea.d.ts.map +1 -0
- package/dist/Textarea.js +39 -0
- package/dist/Textarea.js.map +1 -0
- package/dist/Textarea.native.d.ts +16 -0
- package/dist/Textarea.native.d.ts.map +1 -0
- package/dist/Textarea.native.js +30 -0
- package/dist/Textarea.native.js.map +1 -0
- package/dist/TiptapEditor.d.ts +24 -0
- package/dist/TiptapEditor.d.ts.map +1 -0
- package/dist/TiptapEditor.js +84 -0
- package/dist/TiptapEditor.js.map +1 -0
- package/dist/TitleBar.d.ts +31 -0
- package/dist/TitleBar.d.ts.map +1 -0
- package/dist/TitleBar.js +27 -0
- package/dist/TitleBar.js.map +1 -0
- package/dist/TitleBar.native.d.ts +19 -0
- package/dist/TitleBar.native.d.ts.map +1 -0
- package/dist/TitleBar.native.js +16 -0
- package/dist/TitleBar.native.js.map +1 -0
- package/dist/Toast.d.ts +72 -0
- package/dist/Toast.d.ts.map +1 -0
- package/dist/Toast.js +194 -0
- package/dist/Toast.js.map +1 -0
- package/dist/Toast.native.d.ts +65 -0
- package/dist/Toast.native.d.ts.map +1 -0
- package/dist/Toast.native.js +182 -0
- package/dist/Toast.native.js.map +1 -0
- package/dist/Toggle.d.ts +46 -0
- package/dist/Toggle.d.ts.map +1 -0
- package/dist/Toggle.js +70 -0
- package/dist/Toggle.js.map +1 -0
- package/dist/Toggle.native.d.ts +42 -0
- package/dist/Toggle.native.d.ts.map +1 -0
- package/dist/Toggle.native.js +56 -0
- package/dist/Toggle.native.js.map +1 -0
- package/dist/Tooltip.d.ts +32 -0
- package/dist/Tooltip.d.ts.map +1 -0
- package/dist/Tooltip.js +43 -0
- package/dist/Tooltip.js.map +1 -0
- package/dist/Tooltip.native.d.ts +25 -0
- package/dist/Tooltip.native.d.ts.map +1 -0
- package/dist/Tooltip.native.js +25 -0
- package/dist/Tooltip.native.js.map +1 -0
- package/dist/TopBar.d.ts +105 -0
- package/dist/TopBar.d.ts.map +1 -0
- package/dist/TopBar.js +90 -0
- package/dist/TopBar.js.map +1 -0
- package/dist/TopBar.native.d.ts +67 -0
- package/dist/TopBar.native.d.ts.map +1 -0
- package/dist/TopBar.native.js +41 -0
- package/dist/TopBar.native.js.map +1 -0
- package/dist/Tracker.d.ts +44 -0
- package/dist/Tracker.d.ts.map +1 -0
- package/dist/Tracker.js +92 -0
- package/dist/Tracker.js.map +1 -0
- package/dist/TransferList.d.ts +51 -0
- package/dist/TransferList.d.ts.map +1 -0
- package/dist/TransferList.js +107 -0
- package/dist/TransferList.js.map +1 -0
- package/dist/TransferList.native.d.ts +14 -0
- package/dist/TransferList.native.d.ts.map +1 -0
- package/dist/TransferList.native.js +57 -0
- package/dist/TransferList.native.js.map +1 -0
- package/dist/index.d.ts +78 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +79 -0
- package/dist/index.js.map +1 -0
- package/dist/internal/cn.d.ts +7 -0
- package/dist/internal/cn.d.ts.map +1 -0
- package/dist/internal/cn.js +30 -0
- package/dist/internal/cn.js.map +1 -0
- package/package.json +499 -0
- package/src/AccessLevelGroup.native.tsx +103 -0
- package/src/AccessLevelGroup.tsx +103 -0
- package/src/Accordion.native.tsx +199 -0
- package/src/Accordion.tsx +279 -0
- package/src/Alert.native.tsx +100 -0
- package/src/Alert.tsx +101 -0
- package/src/AlertDialog.native.tsx +189 -0
- package/src/AlertDialog.tsx +194 -0
- package/src/AspectRatio.native.tsx +28 -0
- package/src/AspectRatio.tsx +35 -0
- package/src/Avatar.native.tsx +142 -0
- package/src/Avatar.tsx +155 -0
- package/src/AvatarGroup.native.tsx +81 -0
- package/src/AvatarGroup.tsx +114 -0
- package/src/Badge.native.tsx +85 -0
- package/src/Badge.tsx +93 -0
- package/src/Banner.native.tsx +77 -0
- package/src/Banner.tsx +95 -0
- package/src/BarList.tsx +102 -0
- package/src/Breadcrumb.native.tsx +238 -0
- package/src/Breadcrumb.tsx +258 -0
- package/src/Button.native.tsx +123 -0
- package/src/Button.tsx +153 -0
- package/src/Calendar.native.tsx +28 -0
- package/src/Calendar.tsx +211 -0
- package/src/Card.native.tsx +82 -0
- package/src/Card.tsx +94 -0
- package/src/Carousel.native.tsx +224 -0
- package/src/Carousel.tsx +292 -0
- package/src/CategoryBar.tsx +85 -0
- package/src/Chart.tsx +467 -0
- package/src/Checkbox.native.tsx +69 -0
- package/src/Checkbox.tsx +108 -0
- package/src/CheckboxGrid.native.tsx +160 -0
- package/src/CheckboxGrid.tsx +262 -0
- package/src/Collapsible.native.tsx +240 -0
- package/src/Collapsible.tsx +241 -0
- package/src/Combobox.native.tsx +171 -0
- package/src/Combobox.tsx +272 -0
- package/src/Command.native.tsx +71 -0
- package/src/Command.tsx +203 -0
- package/src/ContextMenu.native.tsx +313 -0
- package/src/ContextMenu.tsx +238 -0
- package/src/DataTable.native.tsx +70 -0
- package/src/DataTable.tsx +989 -0
- package/src/DatePicker.native.tsx +46 -0
- package/src/DatePicker.tsx +357 -0
- package/src/Dialog.native.tsx +181 -0
- package/src/Dialog.tsx +224 -0
- package/src/Drawer.native.tsx +134 -0
- package/src/Drawer.tsx +119 -0
- package/src/DropdownMenu.native.tsx +258 -0
- package/src/DropdownMenu.tsx +387 -0
- package/src/Dropzone.tsx +95 -0
- package/src/EmptyState.native.tsx +43 -0
- package/src/EmptyState.tsx +52 -0
- package/src/Form.native.tsx +94 -0
- package/src/Form.tsx +1324 -0
- package/src/HoverCard.native.tsx +63 -0
- package/src/HoverCard.tsx +181 -0
- package/src/IconSidebar.native.tsx +94 -0
- package/src/IconSidebar.tsx +448 -0
- package/src/Input.native.tsx +99 -0
- package/src/Input.tsx +132 -0
- package/src/InputOTP.native.tsx +154 -0
- package/src/InputOTP.tsx +119 -0
- package/src/Label.native.tsx +55 -0
- package/src/Label.tsx +60 -0
- package/src/Link.native.tsx +89 -0
- package/src/Link.tsx +85 -0
- package/src/Logo.native.tsx +114 -0
- package/src/Logo.tsx +153 -0
- package/src/MainSidebar.native.tsx +8 -0
- package/src/MainSidebar.tsx +10 -0
- package/src/Menubar.tsx +485 -0
- package/src/NavigationMenu.native.tsx +136 -0
- package/src/NavigationMenu.tsx +180 -0
- package/src/NotificationBadge.native.tsx +80 -0
- package/src/NotificationBadge.tsx +91 -0
- package/src/PageShell.native.tsx +43 -0
- package/src/PageShell.tsx +50 -0
- package/src/Pagination.native.tsx +217 -0
- package/src/Pagination.tsx +250 -0
- package/src/Popover.native.tsx +139 -0
- package/src/Popover.tsx +175 -0
- package/src/Popper.tsx +399 -0
- package/src/Progress.native.tsx +197 -0
- package/src/Progress.tsx +286 -0
- package/src/ProgressCircle.tsx +200 -0
- package/src/RadioCardGroup.tsx +97 -0
- package/src/RadioGroup.native.tsx +153 -0
- package/src/RadioGroup.tsx +201 -0
- package/src/Resizable.native.tsx +76 -0
- package/src/Resizable.tsx +88 -0
- package/src/RichTextEditor.tsx +513 -0
- package/src/ScrollArea.native.tsx +36 -0
- package/src/ScrollArea.tsx +62 -0
- package/src/SearchField.native.tsx +104 -0
- package/src/SearchField.tsx +136 -0
- package/src/SectionHeader.native.tsx +226 -0
- package/src/SectionHeader.tsx +250 -0
- package/src/Select.native.tsx +299 -0
- package/src/Select.tsx +710 -0
- package/src/Separator.native.tsx +38 -0
- package/src/Separator.tsx +43 -0
- package/src/Sheet.native.tsx +233 -0
- package/src/Sheet.tsx +329 -0
- package/src/Sidebar.tsx +956 -0
- package/src/Skeleton.native.tsx +47 -0
- package/src/Skeleton.tsx +29 -0
- package/src/Slider.native.tsx +64 -0
- package/src/Slider.tsx +284 -0
- package/src/SortableList.tsx +158 -0
- package/src/SparkChart.tsx +143 -0
- package/src/StatCard.native.tsx +64 -0
- package/src/StatCard.tsx +75 -0
- package/src/StatusBadge.native.tsx +57 -0
- package/src/StatusBadge.tsx +52 -0
- package/src/Switch.native.tsx +78 -0
- package/src/Switch.tsx +94 -0
- package/src/TabNavigation.tsx +329 -0
- package/src/Table.native.tsx +183 -0
- package/src/Table.tsx +260 -0
- package/src/Tabs.native.tsx +139 -0
- package/src/Tabs.tsx +216 -0
- package/src/Tag.native.tsx +87 -0
- package/src/Tag.tsx +93 -0
- package/src/Text.native.tsx +95 -0
- package/src/Text.tsx +93 -0
- package/src/Textarea.native.tsx +64 -0
- package/src/Textarea.tsx +66 -0
- package/src/TitleBar.native.tsx +46 -0
- package/src/TitleBar.tsx +64 -0
- package/src/Toast.native.tsx +366 -0
- package/src/Toast.tsx +408 -0
- package/src/Toggle.native.tsx +162 -0
- package/src/Toggle.tsx +169 -0
- package/src/Tooltip.native.tsx +62 -0
- package/src/Tooltip.tsx +88 -0
- package/src/TopBar.native.tsx +223 -0
- package/src/TopBar.tsx +436 -0
- package/src/Tracker.tsx +244 -0
- package/src/TransferList.native.tsx +180 -0
- package/src/TransferList.tsx +297 -0
- package/src/globals.d.ts +1 -0
- package/src/index.ts +502 -0
- package/src/internal/cn.ts +31 -0
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ContextMenu (React Native variant).
|
|
3
|
+
*
|
|
4
|
+
* Uses Modal for the overlay and Pressable for items.
|
|
5
|
+
* Long-press on the trigger opens the menu.
|
|
6
|
+
* Same sub-component API as the web variant.
|
|
7
|
+
*
|
|
8
|
+
* Wiki: docs/components/ContextMenu.md
|
|
9
|
+
*/
|
|
10
|
+
import { type ReactNode } from 'react';
|
|
11
|
+
import { View, type ViewProps } from 'react-native';
|
|
12
|
+
import { type VariantProps } from 'class-variance-authority';
|
|
13
|
+
type ClassedViewProps = Omit<ViewProps, 'style'> & {
|
|
14
|
+
className?: string;
|
|
15
|
+
};
|
|
16
|
+
export interface ContextMenuProps {
|
|
17
|
+
children: ReactNode;
|
|
18
|
+
}
|
|
19
|
+
export declare function ContextMenu({ children }: ContextMenuProps): import("react/jsx-runtime").JSX.Element;
|
|
20
|
+
export interface ContextMenuTriggerProps extends ClassedViewProps {
|
|
21
|
+
children: ReactNode;
|
|
22
|
+
}
|
|
23
|
+
export declare const ContextMenuTrigger: import("react").ForwardRefExoticComponent<ContextMenuTriggerProps & import("react").RefAttributes<View>>;
|
|
24
|
+
export interface ContextMenuContentProps extends ClassedViewProps {
|
|
25
|
+
}
|
|
26
|
+
export declare const ContextMenuContent: import("react").ForwardRefExoticComponent<ContextMenuContentProps & import("react").RefAttributes<View>>;
|
|
27
|
+
declare const contextMenuItemVariants: (props?: ({
|
|
28
|
+
variant?: "default" | "destructive" | null | undefined;
|
|
29
|
+
} & import("class-variance-authority/types").ClassProp) | undefined) => string;
|
|
30
|
+
export interface ContextMenuItemProps extends ClassedViewProps, VariantProps<typeof contextMenuItemVariants> {
|
|
31
|
+
disabled?: boolean;
|
|
32
|
+
onSelect?: () => void;
|
|
33
|
+
inset?: boolean;
|
|
34
|
+
children: ReactNode;
|
|
35
|
+
}
|
|
36
|
+
export declare const ContextMenuItem: import("react").ForwardRefExoticComponent<ContextMenuItemProps & import("react").RefAttributes<View>>;
|
|
37
|
+
export interface ContextMenuCheckboxItemProps extends ClassedViewProps {
|
|
38
|
+
checked?: boolean;
|
|
39
|
+
onCheckedChange?: (checked: boolean) => void;
|
|
40
|
+
disabled?: boolean;
|
|
41
|
+
children: ReactNode;
|
|
42
|
+
}
|
|
43
|
+
export declare const ContextMenuCheckboxItem: import("react").ForwardRefExoticComponent<ContextMenuCheckboxItemProps & import("react").RefAttributes<View>>;
|
|
44
|
+
export interface ContextMenuRadioItemProps extends ClassedViewProps {
|
|
45
|
+
value: string;
|
|
46
|
+
disabled?: boolean;
|
|
47
|
+
children: ReactNode;
|
|
48
|
+
}
|
|
49
|
+
export declare const ContextMenuRadioItem: import("react").ForwardRefExoticComponent<ContextMenuRadioItemProps & import("react").RefAttributes<View>>;
|
|
50
|
+
export declare const ContextMenuGroup: import("react").ForwardRefExoticComponent<Omit<ViewProps, "style"> & {
|
|
51
|
+
className?: string;
|
|
52
|
+
} & import("react").RefAttributes<View>>;
|
|
53
|
+
export declare const ContextMenuSub: ({ children }: {
|
|
54
|
+
children: ReactNode;
|
|
55
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
56
|
+
export declare const ContextMenuRadioGroup: ({ children }: {
|
|
57
|
+
children: ReactNode;
|
|
58
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
59
|
+
export interface ContextMenuLabelProps extends ClassedViewProps {
|
|
60
|
+
inset?: boolean;
|
|
61
|
+
children: ReactNode;
|
|
62
|
+
}
|
|
63
|
+
export declare const ContextMenuLabel: import("react").ForwardRefExoticComponent<ContextMenuLabelProps & import("react").RefAttributes<View>>;
|
|
64
|
+
export declare const ContextMenuSeparator: import("react").ForwardRefExoticComponent<Omit<ViewProps, "style"> & {
|
|
65
|
+
className?: string;
|
|
66
|
+
} & import("react").RefAttributes<View>>;
|
|
67
|
+
export declare const ContextMenuSubTrigger: import("react").ForwardRefExoticComponent<Omit<ViewProps, "style"> & {
|
|
68
|
+
className?: string;
|
|
69
|
+
} & {
|
|
70
|
+
inset?: boolean;
|
|
71
|
+
children: ReactNode;
|
|
72
|
+
} & import("react").RefAttributes<View>>;
|
|
73
|
+
export declare const ContextMenuSubContent: import("react").ForwardRefExoticComponent<Omit<ViewProps, "style"> & {
|
|
74
|
+
className?: string;
|
|
75
|
+
} & import("react").RefAttributes<View>>;
|
|
76
|
+
export interface ContextMenuShortcutProps extends ClassedViewProps {
|
|
77
|
+
children: ReactNode;
|
|
78
|
+
}
|
|
79
|
+
export declare const ContextMenuShortcut: import("react").ForwardRefExoticComponent<ContextMenuShortcutProps & import("react").RefAttributes<View>>;
|
|
80
|
+
export {};
|
|
81
|
+
//# sourceMappingURL=ContextMenu.native.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ContextMenu.native.d.ts","sourceRoot":"","sources":["../src/ContextMenu.native.tsx"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AACH,OAAO,EAML,KAAK,SAAS,EACf,MAAM,OAAO,CAAC;AACf,OAAO,EAIL,IAAI,EACJ,KAAK,SAAS,EACf,MAAM,cAAc,CAAC;AACtB,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAGlE,KAAK,gBAAgB,GAAG,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,GAAG;IAAE,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC;AAmB1E,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,wBAAgB,WAAW,CAAC,EAAE,QAAQ,EAAE,EAAE,gBAAgB,2CAQzD;AAID,MAAM,WAAW,uBAAwB,SAAQ,gBAAgB;IAC/D,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,kBAAkB,0GAgB9B,CAAC;AAIF,MAAM,WAAW,uBAAwB,SAAQ,gBAAgB;CAAG;AAEpE,eAAO,MAAM,kBAAkB,0GAkC9B,CAAC;AAIF,QAAA,MAAM,uBAAuB;;8EAW5B,CAAC;AAEF,MAAM,WAAW,oBACf,SAAQ,gBAAgB,EACtB,YAAY,CAAC,OAAO,uBAAuB,CAAC;IAC9C,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,eAAe,uGAoC3B,CAAC;AAIF,MAAM,WAAW,4BAA6B,SAAQ,gBAAgB;IACpE,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;IAC7C,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,uBAAuB,+GAmBnC,CAAC;AAIF,MAAM,WAAW,yBAA0B,SAAQ,gBAAgB;IACjE,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,oBAAoB,4GAehC,CAAC;AAIF,eAAO,MAAM,gBAAgB;gBAxNoC,MAAM;wCA4NtE,CAAC;AAEF,eAAO,MAAM,cAAc,GAAI,cAAc;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,4CAAoB,CAAC;AACzF,eAAO,MAAM,qBAAqB,GAAI,cAAc;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,4CAAoB,CAAC;AAIhG,MAAM,WAAW,qBAAsB,SAAQ,gBAAgB;IAC7D,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,gBAAgB,wGAQ5B,CAAC;AAIF,eAAO,MAAM,oBAAoB;gBApPgC,MAAM;wCA0PtE,CAAC;AAIF,eAAO,MAAM,qBAAqB;gBA9P+B,MAAM;;YA8PY,OAAO;cAAY,SAAS;wCAS9G,CAAC;AAEF,eAAO,MAAM,qBAAqB;gBAzQ+B,MAAM;wCA6QtE,CAAC;AAIF,MAAM,WAAW,wBAAyB,SAAQ,gBAAgB;IAChE,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,mBAAmB,2GAQ/B,CAAC"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* ContextMenu (React Native variant).
|
|
4
|
+
*
|
|
5
|
+
* Uses Modal for the overlay and Pressable for items.
|
|
6
|
+
* Long-press on the trigger opens the menu.
|
|
7
|
+
* Same sub-component API as the web variant.
|
|
8
|
+
*
|
|
9
|
+
* Wiki: docs/components/ContextMenu.md
|
|
10
|
+
*/
|
|
11
|
+
import { forwardRef, createContext, useContext, useCallback, useState, } from 'react';
|
|
12
|
+
import { Modal, Pressable, Text, View, } from 'react-native';
|
|
13
|
+
import { cva } from 'class-variance-authority';
|
|
14
|
+
import { cn } from './internal/cn.js';
|
|
15
|
+
const ContextMenuCtx = createContext(null);
|
|
16
|
+
function useCtx() {
|
|
17
|
+
const ctx = useContext(ContextMenuCtx);
|
|
18
|
+
if (!ctx)
|
|
19
|
+
throw new Error('ContextMenu sub-components must be used within <ContextMenu>.');
|
|
20
|
+
return ctx;
|
|
21
|
+
}
|
|
22
|
+
export function ContextMenu({ children }) {
|
|
23
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
24
|
+
return (_jsx(ContextMenuCtx.Provider, { value: { open: isOpen, setOpen: setIsOpen }, children: children }));
|
|
25
|
+
}
|
|
26
|
+
export const ContextMenuTrigger = forwardRef(function ContextMenuTrigger({ className, children, ...props }, ref) {
|
|
27
|
+
const ctx = useCtx();
|
|
28
|
+
return (_jsx(Pressable, { ref: ref, onLongPress: () => ctx.setOpen(true), delayLongPress: 500, className: cn(className), ...props, children: children }));
|
|
29
|
+
});
|
|
30
|
+
export const ContextMenuContent = forwardRef(function ContextMenuContent({ className, children, ...props }, ref) {
|
|
31
|
+
const ctx = useCtx();
|
|
32
|
+
return (_jsx(Modal, { visible: ctx.open, transparent: true, animationType: "fade", onRequestClose: () => ctx.setOpen(false), statusBarTranslucent: true, children: _jsx(Pressable, { onPress: () => ctx.setOpen(false), className: "flex-1 items-center justify-center bg-black/40", accessibilityRole: "none", children: _jsx(Pressable, { onPress: (e) => e.stopPropagation(), children: _jsx(View, { ref: ref, accessibilityRole: "menu", className: cn('min-w-[200px] rounded-xl border border-border bg-card p-1 shadow-lg', className), ...props, children: children }) }) }) }));
|
|
33
|
+
});
|
|
34
|
+
/* ── Item ──────────────────────────────────────────────────────────── */
|
|
35
|
+
const contextMenuItemVariants = cva('flex-row items-center rounded-lg px-3 py-3', {
|
|
36
|
+
variants: {
|
|
37
|
+
variant: {
|
|
38
|
+
default: '',
|
|
39
|
+
destructive: '',
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
defaultVariants: { variant: 'default' },
|
|
43
|
+
});
|
|
44
|
+
export const ContextMenuItem = forwardRef(function ContextMenuItem({ className, variant, disabled, onSelect, inset, children, ...props }, ref) {
|
|
45
|
+
const ctx = useCtx();
|
|
46
|
+
return (_jsx(Pressable, { ref: ref, accessibilityRole: "menuitem", accessibilityState: { disabled: !!disabled }, disabled: disabled, onPress: () => {
|
|
47
|
+
if (!disabled) {
|
|
48
|
+
onSelect?.();
|
|
49
|
+
ctx.setOpen(false);
|
|
50
|
+
}
|
|
51
|
+
}, className: cn(contextMenuItemVariants({ variant }), disabled && 'opacity-50', inset && 'pl-8', className), ...props, children: _jsx(Text, { className: cn('flex-1 text-sm', variant === 'destructive' ? 'text-destructive' : 'text-foreground'), numberOfLines: 1, children: children }) }));
|
|
52
|
+
});
|
|
53
|
+
export const ContextMenuCheckboxItem = forwardRef(function ContextMenuCheckboxItem({ className, checked, onCheckedChange, disabled, children, ...props }, ref) {
|
|
54
|
+
return (_jsxs(Pressable, { ref: ref, accessibilityRole: "checkbox", accessibilityState: { checked: !!checked, disabled: !!disabled }, disabled: disabled, onPress: () => onCheckedChange?.(!checked), className: cn('flex-row items-center rounded-lg px-3 py-3 pl-8', disabled && 'opacity-50', className), ...props, children: [checked && (_jsx(Text, { className: "absolute left-2 text-foreground", children: "\u2713" })), _jsx(Text, { className: "flex-1 text-sm text-foreground", numberOfLines: 1, children: children })] }));
|
|
55
|
+
});
|
|
56
|
+
export const ContextMenuRadioItem = forwardRef(function ContextMenuRadioItem({ className, disabled, children, ...props }, ref) {
|
|
57
|
+
return (_jsx(Pressable, { ref: ref, accessibilityRole: "radio", accessibilityState: { disabled: !!disabled }, disabled: disabled, className: cn('flex-row items-center rounded-lg px-3 py-3 pl-8', disabled && 'opacity-50', className), ...props, children: _jsx(Text, { className: "flex-1 text-sm text-foreground", numberOfLines: 1, children: children }) }));
|
|
58
|
+
});
|
|
59
|
+
/* ── Group + RadioGroup ───────────────────────────────────────────── */
|
|
60
|
+
export const ContextMenuGroup = forwardRef(function ContextMenuGroup({ className, ...props }, ref) {
|
|
61
|
+
return _jsx(View, { ref: ref, className: cn('py-1', className), ...props });
|
|
62
|
+
});
|
|
63
|
+
export const ContextMenuSub = ({ children }) => _jsx(_Fragment, { children: children });
|
|
64
|
+
export const ContextMenuRadioGroup = ({ children }) => _jsx(_Fragment, { children: children });
|
|
65
|
+
export const ContextMenuLabel = forwardRef(function ContextMenuLabel({ className, inset, children, ...props }, ref) {
|
|
66
|
+
return (_jsx(View, { ref: ref, className: cn('px-3 py-1.5', inset && 'pl-8', className), ...props, children: _jsx(Text, { className: "text-xs font-semibold text-muted-foreground", children: children }) }));
|
|
67
|
+
});
|
|
68
|
+
/* ── Separator ────────────────────────────────────────────────────── */
|
|
69
|
+
export const ContextMenuSeparator = forwardRef(function ContextMenuSeparator({ className, ...props }, ref) {
|
|
70
|
+
return (_jsx(View, { ref: ref, className: cn('my-1 h-px bg-border', className), ...props }));
|
|
71
|
+
});
|
|
72
|
+
/* ── SubTrigger + SubContent (passthrough on native) ─────────────── */
|
|
73
|
+
export const ContextMenuSubTrigger = forwardRef(function ContextMenuSubTrigger({ className, inset, children, ...props }, ref) {
|
|
74
|
+
return (_jsxs(View, { ref: ref, className: cn('flex-row items-center rounded-lg px-3 py-3', inset && 'pl-8', className), ...props, children: [_jsx(Text, { className: "flex-1 text-sm text-foreground", children: children }), _jsx(Text, { className: "text-xs text-muted-foreground", children: "\u203A" })] }));
|
|
75
|
+
});
|
|
76
|
+
export const ContextMenuSubContent = forwardRef(function ContextMenuSubContent({ className, ...props }, ref) {
|
|
77
|
+
return _jsx(View, { ref: ref, className: cn(className), ...props });
|
|
78
|
+
});
|
|
79
|
+
export const ContextMenuShortcut = forwardRef(function ContextMenuShortcut({ className, children, ...props }, ref) {
|
|
80
|
+
return (_jsx(View, { ref: ref, className: cn('ml-auto pl-4', className), ...props, children: _jsx(Text, { className: "text-xs tracking-widest text-muted-foreground", children: children }) }));
|
|
81
|
+
});
|
|
82
|
+
//# sourceMappingURL=ContextMenu.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ContextMenu.native.js","sourceRoot":"","sources":["../src/ContextMenu.native.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* DataTable (web variant — React DOM).
|
|
3
|
+
*
|
|
4
|
+
* Full-featured data table powered by TanStack Table v8 and rendered
|
|
5
|
+
* with the design system's Table primitives. Supports sorting,
|
|
6
|
+
* filtering, pagination, row selection, column visibility,
|
|
7
|
+
* expandable rows, column resizing, column/row pinning, grouping,
|
|
8
|
+
* and faceted filtering — all toggled via boolean props.
|
|
9
|
+
*
|
|
10
|
+
* Wiki: docs/components/DataTable.md
|
|
11
|
+
*/
|
|
12
|
+
import { type ReactNode } from 'react';
|
|
13
|
+
import { createColumnHelper, type ColumnDef, type RowSelectionState, type Row, type Column } from '@tanstack/react-table';
|
|
14
|
+
import { type TableHeaderTone, type TableVariant } from './Table.js';
|
|
15
|
+
export { createColumnHelper };
|
|
16
|
+
export type { ColumnDef, Row, RowSelectionState, TableVariant };
|
|
17
|
+
interface DataTableColumnHeaderProps<TData, TValue> {
|
|
18
|
+
column: Column<TData, TValue>;
|
|
19
|
+
title: string;
|
|
20
|
+
className?: string;
|
|
21
|
+
}
|
|
22
|
+
export declare function DataTableColumnHeader<TData, TValue>({ column, title, className, }: DataTableColumnHeaderProps<TData, TValue>): import("react/jsx-runtime").JSX.Element;
|
|
23
|
+
export interface DataTableProps<TData, TValue> {
|
|
24
|
+
columns: ColumnDef<TData, TValue>[];
|
|
25
|
+
data: TData[];
|
|
26
|
+
/** Show a global search input above the table. */
|
|
27
|
+
searchable?: boolean;
|
|
28
|
+
/** Placeholder for the search input. */
|
|
29
|
+
searchPlaceholder?: string;
|
|
30
|
+
/** Enable column header click-to-sort. @default true */
|
|
31
|
+
sortable?: boolean;
|
|
32
|
+
/** Show pagination controls below the table. */
|
|
33
|
+
paginated?: boolean;
|
|
34
|
+
/** Rows per page when `paginated` is true. @default 10 */
|
|
35
|
+
pageSize?: number;
|
|
36
|
+
/** Options for the rows-per-page selector. @default [5, 10, 20, 50] */
|
|
37
|
+
pageSizeOptions?: number[];
|
|
38
|
+
/** Add a selection checkbox column. */
|
|
39
|
+
selectable?: boolean;
|
|
40
|
+
/** Show a column-visibility toggle dropdown. */
|
|
41
|
+
columnVisibility?: boolean;
|
|
42
|
+
/** Enable expandable rows. */
|
|
43
|
+
expandable?: boolean;
|
|
44
|
+
/** Row-level guard for expand. */
|
|
45
|
+
getRowCanExpand?: (row: Row<TData>) => boolean;
|
|
46
|
+
/** Content rendered when a row is expanded. */
|
|
47
|
+
renderSubComponent?: (props: {
|
|
48
|
+
row: Row<TData>;
|
|
49
|
+
}) => ReactNode;
|
|
50
|
+
/** Called whenever row selection changes. */
|
|
51
|
+
onRowSelectionChange?: (selection: RowSelectionState) => void;
|
|
52
|
+
/** Enable per-column filter inputs below each header. */
|
|
53
|
+
columnFilterable?: boolean;
|
|
54
|
+
/** Allow shift+click to sort by multiple columns. */
|
|
55
|
+
multiSort?: boolean;
|
|
56
|
+
/** Allow columns to be resized by dragging the header edge. */
|
|
57
|
+
resizable?: boolean;
|
|
58
|
+
/** Enable column pinning. Provide pinned column IDs via `pinnedColumns`. */
|
|
59
|
+
columnPinnable?: boolean;
|
|
60
|
+
/** Column IDs to pin left/right. Only used when `columnPinnable` is true. */
|
|
61
|
+
pinnedColumns?: {
|
|
62
|
+
left?: string[];
|
|
63
|
+
right?: string[];
|
|
64
|
+
};
|
|
65
|
+
/** Enable row pinning. Provide pinned row IDs via `pinnedRows`. */
|
|
66
|
+
rowPinnable?: boolean;
|
|
67
|
+
/** Row IDs to pin top/bottom. Only used when `rowPinnable` is true. */
|
|
68
|
+
pinnedRows?: {
|
|
69
|
+
top?: string[];
|
|
70
|
+
bottom?: string[];
|
|
71
|
+
};
|
|
72
|
+
/** Enable row grouping by column. */
|
|
73
|
+
groupable?: boolean;
|
|
74
|
+
/** Enable faceted filtering (unique value lists, min/max ranges). Requires `columnFilterable`. */
|
|
75
|
+
faceted?: boolean;
|
|
76
|
+
/** Visual style variant for the table. @default 'default' */
|
|
77
|
+
variant?: TableVariant;
|
|
78
|
+
/** Semantic header color. */
|
|
79
|
+
headerTone?: TableHeaderTone;
|
|
80
|
+
/** ClassName applied to every header cell. */
|
|
81
|
+
headerClassName?: string;
|
|
82
|
+
/** Enable a minimum width table layout for wide/large datasets. */
|
|
83
|
+
wide?: boolean;
|
|
84
|
+
/** Render large row sets through TanStack Virtual inside a fixed-height scroll area. */
|
|
85
|
+
virtualized?: boolean;
|
|
86
|
+
/** Scroll container height when `virtualized` is true. */
|
|
87
|
+
virtualHeight?: number;
|
|
88
|
+
/** Estimated row height for TanStack Virtual. */
|
|
89
|
+
estimateRowHeight?: number;
|
|
90
|
+
/** Extra rows rendered before/after the viewport. */
|
|
91
|
+
virtualOverscan?: number;
|
|
92
|
+
/** Additional className on the root wrapper. */
|
|
93
|
+
className?: string;
|
|
94
|
+
/** Message shown when no rows match. @default 'No results.' */
|
|
95
|
+
emptyMessage?: string;
|
|
96
|
+
}
|
|
97
|
+
export declare function DataTable<TData, TValue>({ columns: userColumns, data, searchable, searchPlaceholder, sortable, paginated, pageSize: initialPageSize, pageSizeOptions, selectable, columnVisibility: showColumnVisibility, expandable, getRowCanExpand, renderSubComponent, onRowSelectionChange, columnFilterable, multiSort, resizable, columnPinnable, pinnedColumns, rowPinnable, pinnedRows, groupable, faceted, variant, headerTone, headerClassName, wide, virtualized, virtualHeight, estimateRowHeight, virtualOverscan, className, emptyMessage, }: DataTableProps<TData, TValue>): import("react/jsx-runtime").JSX.Element;
|
|
98
|
+
//# sourceMappingURL=DataTable.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DataTable.d.ts","sourceRoot":"","sources":["../src/DataTable.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,291 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
+
/**
|
|
4
|
+
* DataTable (web variant — React DOM).
|
|
5
|
+
*
|
|
6
|
+
* Full-featured data table powered by TanStack Table v8 and rendered
|
|
7
|
+
* with the design system's Table primitives. Supports sorting,
|
|
8
|
+
* filtering, pagination, row selection, column visibility,
|
|
9
|
+
* expandable rows, column resizing, column/row pinning, grouping,
|
|
10
|
+
* and faceted filtering — all toggled via boolean props.
|
|
11
|
+
*
|
|
12
|
+
* Wiki: docs/components/DataTable.md
|
|
13
|
+
*/
|
|
14
|
+
import { Fragment, useState, useMemo, useCallback, useEffect, useRef, } from 'react';
|
|
15
|
+
import { useReactTable, getCoreRowModel, getSortedRowModel, getFilteredRowModel, getPaginationRowModel, getExpandedRowModel, getGroupedRowModel, getFacetedRowModel, getFacetedMinMaxValues, getFacetedUniqueValues, flexRender, createColumnHelper, } from '@tanstack/react-table';
|
|
16
|
+
import { useVirtualizer } from '@tanstack/react-virtual';
|
|
17
|
+
import { Table, TableHeader, TableBody, TableRow, TableHead, TableCell, } from './Table.js';
|
|
18
|
+
import { Input } from './Input.js';
|
|
19
|
+
import { Button } from './Button.js';
|
|
20
|
+
import { Checkbox } from './Checkbox.js';
|
|
21
|
+
import { Select, SelectTrigger, SelectContent, SelectItem } from './Select.js';
|
|
22
|
+
import { cn } from './internal/cn.js';
|
|
23
|
+
/* ── Re-export for consumer convenience ───────────────────────────── */
|
|
24
|
+
export { createColumnHelper };
|
|
25
|
+
export function DataTableColumnHeader({ column, title, className, }) {
|
|
26
|
+
if (!column.getCanSort()) {
|
|
27
|
+
return _jsx("span", { className: className, children: title });
|
|
28
|
+
}
|
|
29
|
+
const sorted = column.getIsSorted();
|
|
30
|
+
return (_jsxs("button", { type: "button", className: cn('inline-flex items-center gap-1 -ml-1 px-1 py-0.5 rounded-md', 'hover:bg-muted transition-colors duration-150', 'focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring', className), onClick: column.getToggleSortingHandler(), "aria-label": `Sort by ${title}`, children: [title, _jsxs("span", { className: "inline-flex flex-col", "aria-hidden": true, children: [_jsx("svg", { viewBox: "0 0 8 4", className: cn('h-1.5 w-2 transition-transform duration-200', sorted === 'asc' ? 'text-foreground' : 'text-muted-foreground/40'), fill: "currentColor", children: _jsx("path", { d: "M4 0L8 4H0z" }) }), _jsx("svg", { viewBox: "0 0 8 4", className: cn('h-1.5 w-2 transition-transform duration-200', sorted === 'desc' ? 'text-foreground' : 'text-muted-foreground/40'), fill: "currentColor", children: _jsx("path", { d: "M4 4L0 0h8z" }) })] })] }));
|
|
31
|
+
}
|
|
32
|
+
/* ── Column visibility dropdown ───────────────────────────────────── */
|
|
33
|
+
function ColumnVisibilityDropdown({ table, }) {
|
|
34
|
+
const [open, setOpen] = useState(false);
|
|
35
|
+
const ref = useRef(null);
|
|
36
|
+
useEffect(() => {
|
|
37
|
+
if (!open)
|
|
38
|
+
return;
|
|
39
|
+
function handleClick(e) {
|
|
40
|
+
if (ref.current && !ref.current.contains(e.target)) {
|
|
41
|
+
setOpen(false);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
document.addEventListener('mousedown', handleClick);
|
|
45
|
+
return () => document.removeEventListener('mousedown', handleClick);
|
|
46
|
+
}, [open]);
|
|
47
|
+
return (_jsxs("div", { ref: ref, className: "relative", children: [_jsxs(Button, { variant: "outline", size: "sm", onClick: () => setOpen(!open), "aria-expanded": open, "aria-haspopup": "true", children: [_jsx("svg", { "aria-hidden": true, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: 2, className: "h-4 w-4", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M10.5 6h9.75M10.5 6a1.5 1.5 0 11-3 0m3 0a1.5 1.5 0 10-3 0M3.75 6H7.5m3 12h9.75m-9.75 0a1.5 1.5 0 01-3 0m3 0a1.5 1.5 0 00-3 0m-3.75 0H7.5m9-6h3.75m-3.75 0a1.5 1.5 0 01-3 0m3 0a1.5 1.5 0 00-3 0m-9.75 0h9.75" }) }), "Columns"] }), open && (_jsx("div", { className: "absolute right-0 top-full z-50 mt-1 min-w-[10rem] rounded-lg border border-border bg-card p-1 shadow-md", children: table.getAllLeafColumns().map((column) => {
|
|
48
|
+
if (column.id === 'select' || column.id === 'expand')
|
|
49
|
+
return null;
|
|
50
|
+
return (_jsxs("label", { className: "flex cursor-pointer items-center gap-2 rounded-md px-2 py-1.5 text-sm hover:bg-muted transition-colors duration-150", children: [_jsx(Checkbox, { size: "sm", checked: column.getIsVisible(), onCheckedChange: (v) => column.toggleVisibility(!!v) }), _jsx("span", { className: "capitalize", children: typeof column.columnDef.header === 'string'
|
|
51
|
+
? column.columnDef.header
|
|
52
|
+
: column.id })] }, column.id));
|
|
53
|
+
}) }))] }));
|
|
54
|
+
}
|
|
55
|
+
/* ── Column filter input ──────────────────────────────────────────── */
|
|
56
|
+
function ColumnFilterInput({ column, faceted, }) {
|
|
57
|
+
const columnFilterValue = column.getFilterValue();
|
|
58
|
+
const [open, setOpen] = useState(false);
|
|
59
|
+
const ref = useRef(null);
|
|
60
|
+
/* Close faceted dropdown on outside click */
|
|
61
|
+
useEffect(() => {
|
|
62
|
+
if (!open)
|
|
63
|
+
return;
|
|
64
|
+
function handleClick(e) {
|
|
65
|
+
if (ref.current && !ref.current.contains(e.target)) {
|
|
66
|
+
setOpen(false);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
document.addEventListener('mousedown', handleClick);
|
|
70
|
+
return () => document.removeEventListener('mousedown', handleClick);
|
|
71
|
+
}, [open]);
|
|
72
|
+
/* Faceted: number column → min/max range */
|
|
73
|
+
if (faceted) {
|
|
74
|
+
const facetedMinMax = column.getFacetedMinMaxValues?.();
|
|
75
|
+
const isNumberColumn = facetedMinMax !== undefined &&
|
|
76
|
+
facetedMinMax[0] !== undefined &&
|
|
77
|
+
typeof facetedMinMax[0] === 'number';
|
|
78
|
+
if (isNumberColumn) {
|
|
79
|
+
const [min, max] = facetedMinMax;
|
|
80
|
+
const currentRange = columnFilterValue ?? [
|
|
81
|
+
undefined,
|
|
82
|
+
undefined,
|
|
83
|
+
];
|
|
84
|
+
return (_jsxs("div", { className: "grid min-w-[10rem] grid-cols-2 gap-1", children: [_jsx(Input, { type: "number", value: currentRange[0] ?? '', onChange: (e) => {
|
|
85
|
+
const val = e.target.value ? Number(e.target.value) : undefined;
|
|
86
|
+
column.setFilterValue((old) => [
|
|
87
|
+
val,
|
|
88
|
+
old?.[1],
|
|
89
|
+
]);
|
|
90
|
+
}, placeholder: `Min (${min})`, className: "h-8 min-w-0 bg-background px-2 text-xs shadow-mi-input" }), _jsx(Input, { type: "number", value: currentRange[1] ?? '', onChange: (e) => {
|
|
91
|
+
const val = e.target.value ? Number(e.target.value) : undefined;
|
|
92
|
+
column.setFilterValue((old) => [
|
|
93
|
+
old?.[0],
|
|
94
|
+
val,
|
|
95
|
+
]);
|
|
96
|
+
}, placeholder: `Max (${max})`, className: "h-8 min-w-0 bg-background px-2 text-xs shadow-mi-input" })] }));
|
|
97
|
+
}
|
|
98
|
+
/* Faceted: string column → unique values list */
|
|
99
|
+
const uniqueValues = column.getFacetedUniqueValues?.();
|
|
100
|
+
if (uniqueValues && uniqueValues.size > 0) {
|
|
101
|
+
const sortedValues = Array.from(uniqueValues.keys())
|
|
102
|
+
.filter((v) => typeof v === 'string')
|
|
103
|
+
.sort();
|
|
104
|
+
return (_jsxs("div", { ref: ref, className: "relative", children: [_jsx(Input, { type: "text", value: columnFilterValue ?? '', onChange: (e) => column.setFilterValue(e.target.value || undefined), onFocus: () => setOpen(true), placeholder: "Filter...", className: "h-8 min-w-[8rem] bg-background px-2 text-xs shadow-mi-input" }), open && sortedValues.length > 0 && (_jsx("div", { className: "absolute left-0 top-full z-50 mt-1 max-h-40 min-w-full overflow-y-auto rounded-md border border-border bg-card p-1 shadow-mi-modal", children: sortedValues.map((val) => (_jsxs("button", { type: "button", className: "block w-full rounded px-2 py-1 text-left text-xs hover:bg-muted transition-colors duration-150", onClick: () => {
|
|
105
|
+
column.setFilterValue(val);
|
|
106
|
+
setOpen(false);
|
|
107
|
+
}, children: [val, ' ', _jsxs("span", { className: "text-muted-foreground", children: ["(", uniqueValues.get(val), ")"] })] }, val))) }))] }));
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
/* Default: simple text input */
|
|
111
|
+
return (_jsx(Input, { type: "text", value: columnFilterValue ?? '', onChange: (e) => column.setFilterValue(e.target.value || undefined), placeholder: "Filter...", className: "h-8 min-w-[8rem] bg-background px-2 text-xs shadow-mi-input" }));
|
|
112
|
+
}
|
|
113
|
+
export function DataTable({ columns: userColumns, data, searchable = false, searchPlaceholder = 'Search...', sortable = true, paginated = false, pageSize: initialPageSize = 10, pageSizeOptions = [5, 10, 20, 50], selectable = false, columnVisibility: showColumnVisibility = false, expandable = false, getRowCanExpand, renderSubComponent, onRowSelectionChange, columnFilterable = false, multiSort = false, resizable = false, columnPinnable = false, pinnedColumns, rowPinnable = false, pinnedRows, groupable = false, faceted = false, variant = 'default', headerTone = 'default', headerClassName, wide = false, virtualized = false, virtualHeight = 520, estimateRowHeight = 56, virtualOverscan = 8, className, emptyMessage = 'No results.', }) {
|
|
114
|
+
/* ── State ──────────────────────────────────────────────────────── */
|
|
115
|
+
const [sorting, setSorting] = useState([]);
|
|
116
|
+
const [columnFilters, setColumnFilters] = useState([]);
|
|
117
|
+
const [globalFilter, setGlobalFilter] = useState('');
|
|
118
|
+
const [visibility, setVisibility] = useState({});
|
|
119
|
+
const [rowSelection, setRowSelection] = useState({});
|
|
120
|
+
const [expanded, setExpanded] = useState({});
|
|
121
|
+
const [pagination, setPagination] = useState({ pageIndex: 0, pageSize: initialPageSize });
|
|
122
|
+
const [grouping, setGrouping] = useState([]);
|
|
123
|
+
const [columnPinning, setColumnPinning] = useState(pinnedColumns ?? {});
|
|
124
|
+
const [rowPinning, setRowPinning] = useState(pinnedRows ?? {});
|
|
125
|
+
const tableScrollRef = useRef(null);
|
|
126
|
+
/* ── Sync controlled pinning props ─────────────────────────────── */
|
|
127
|
+
useEffect(() => {
|
|
128
|
+
if (columnPinnable && pinnedColumns !== undefined) {
|
|
129
|
+
setColumnPinning(pinnedColumns);
|
|
130
|
+
}
|
|
131
|
+
}, [columnPinnable, pinnedColumns]);
|
|
132
|
+
useEffect(() => {
|
|
133
|
+
if (rowPinnable && pinnedRows !== undefined) {
|
|
134
|
+
setRowPinning(pinnedRows);
|
|
135
|
+
}
|
|
136
|
+
}, [rowPinnable, pinnedRows]);
|
|
137
|
+
/* ── Notify parent of selection changes ─────────────────────────── */
|
|
138
|
+
useEffect(() => {
|
|
139
|
+
onRowSelectionChange?.(rowSelection);
|
|
140
|
+
}, [rowSelection, onRowSelectionChange]);
|
|
141
|
+
/* ── Compose columns (selection + expand + user) ────────────────── */
|
|
142
|
+
const columns = useMemo(() => {
|
|
143
|
+
const cols = [];
|
|
144
|
+
if (selectable) {
|
|
145
|
+
cols.push({
|
|
146
|
+
id: 'select',
|
|
147
|
+
header: ({ table }) => (_jsx(Checkbox, { checked: table.getIsAllPageRowsSelected()
|
|
148
|
+
? true
|
|
149
|
+
: table.getIsSomePageRowsSelected()
|
|
150
|
+
? 'indeterminate'
|
|
151
|
+
: false, onCheckedChange: (v) => table.toggleAllPageRowsSelected(!!v), "aria-label": "Select all" })),
|
|
152
|
+
cell: ({ row }) => (_jsx(Checkbox, { checked: row.getIsSelected(), onCheckedChange: (v) => row.toggleSelected(!!v), "aria-label": "Select row" })),
|
|
153
|
+
enableSorting: false,
|
|
154
|
+
enableHiding: false,
|
|
155
|
+
enableColumnFilter: false,
|
|
156
|
+
enableGrouping: false,
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
if (expandable) {
|
|
160
|
+
cols.push({
|
|
161
|
+
id: 'expand',
|
|
162
|
+
header: () => null,
|
|
163
|
+
cell: ({ row }) => row.getCanExpand() ? (_jsx("button", { type: "button", onClick: row.getToggleExpandedHandler(), "aria-label": row.getIsExpanded() ? 'Collapse row' : 'Expand row', className: "p-1 rounded-md hover:bg-muted transition-colors duration-150 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring", children: _jsx("svg", { "aria-hidden": true, viewBox: "0 0 16 16", fill: "none", stroke: "currentColor", strokeWidth: 2, className: cn('h-4 w-4 transition-transform duration-200', row.getIsExpanded() && 'rotate-90'), children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M6 4l4 4-4 4" }) }) })) : null,
|
|
164
|
+
enableSorting: false,
|
|
165
|
+
enableHiding: false,
|
|
166
|
+
enableColumnFilter: false,
|
|
167
|
+
enableGrouping: false,
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
cols.push(...userColumns);
|
|
171
|
+
return cols;
|
|
172
|
+
}, [userColumns, selectable, expandable]);
|
|
173
|
+
/* ── Table instance ─────────────────────────────────────────────── */
|
|
174
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
175
|
+
const table = useReactTable({
|
|
176
|
+
data,
|
|
177
|
+
columns,
|
|
178
|
+
state: {
|
|
179
|
+
sorting,
|
|
180
|
+
columnFilters,
|
|
181
|
+
globalFilter,
|
|
182
|
+
columnVisibility: visibility,
|
|
183
|
+
rowSelection,
|
|
184
|
+
expanded,
|
|
185
|
+
pagination,
|
|
186
|
+
...(groupable ? { grouping } : {}),
|
|
187
|
+
...(columnPinnable ? { columnPinning } : {}),
|
|
188
|
+
...(rowPinnable ? { rowPinning } : {}),
|
|
189
|
+
},
|
|
190
|
+
enableSorting: sortable,
|
|
191
|
+
...(multiSort ? { enableMultiSort: true } : {}),
|
|
192
|
+
...(resizable
|
|
193
|
+
? { enableColumnResizing: true, columnResizeMode: 'onChange' }
|
|
194
|
+
: {}),
|
|
195
|
+
autoResetPageIndex: false,
|
|
196
|
+
onSortingChange: setSorting,
|
|
197
|
+
onColumnFiltersChange: setColumnFilters,
|
|
198
|
+
onGlobalFilterChange: setGlobalFilter,
|
|
199
|
+
onColumnVisibilityChange: setVisibility,
|
|
200
|
+
onRowSelectionChange: setRowSelection,
|
|
201
|
+
onExpandedChange: setExpanded,
|
|
202
|
+
onPaginationChange: setPagination,
|
|
203
|
+
...(groupable ? { onGroupingChange: setGrouping } : {}),
|
|
204
|
+
...(columnPinnable ? { onColumnPinningChange: setColumnPinning } : {}),
|
|
205
|
+
...(rowPinnable ? { onRowPinningChange: setRowPinning } : {}),
|
|
206
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
207
|
+
getRowCanExpand: getRowCanExpand ?? (() => expandable),
|
|
208
|
+
getCoreRowModel: getCoreRowModel(),
|
|
209
|
+
getSortedRowModel: getSortedRowModel(),
|
|
210
|
+
getFilteredRowModel: getFilteredRowModel(),
|
|
211
|
+
getPaginationRowModel: getPaginationRowModel(),
|
|
212
|
+
getExpandedRowModel: getExpandedRowModel(),
|
|
213
|
+
...(groupable ? { getGroupedRowModel: getGroupedRowModel() } : {}),
|
|
214
|
+
...(faceted
|
|
215
|
+
? {
|
|
216
|
+
getFacetedRowModel: getFacetedRowModel(),
|
|
217
|
+
getFacetedMinMaxValues: getFacetedMinMaxValues(),
|
|
218
|
+
getFacetedUniqueValues: getFacetedUniqueValues(),
|
|
219
|
+
}
|
|
220
|
+
: {}),
|
|
221
|
+
});
|
|
222
|
+
/* ── Pagination helpers ─────────────────────────────────────────── */
|
|
223
|
+
const pageIndex = table.getState().pagination.pageIndex;
|
|
224
|
+
const pageCount = table.getPageCount();
|
|
225
|
+
const regularRows = table.getRowModel().rows;
|
|
226
|
+
const rowVirtualizer = useVirtualizer({
|
|
227
|
+
count: regularRows.length,
|
|
228
|
+
getScrollElement: () => tableScrollRef.current,
|
|
229
|
+
estimateSize: () => estimateRowHeight,
|
|
230
|
+
overscan: virtualOverscan,
|
|
231
|
+
enabled: virtualized,
|
|
232
|
+
});
|
|
233
|
+
const virtualRows = virtualized ? rowVirtualizer.getVirtualItems() : [];
|
|
234
|
+
const topVirtualPadding = virtualized && virtualRows.length > 0 ? virtualRows[0]?.start ?? 0 : 0;
|
|
235
|
+
const bottomVirtualPadding = virtualized && virtualRows.length > 0
|
|
236
|
+
? rowVirtualizer.getTotalSize() - (virtualRows.at(-1)?.end ?? 0)
|
|
237
|
+
: 0;
|
|
238
|
+
const rowsToRender = virtualized
|
|
239
|
+
? virtualRows.map((virtualRow) => regularRows[virtualRow.index]).filter((row) => Boolean(row))
|
|
240
|
+
: regularRows;
|
|
241
|
+
/* ── Pinning style helper ──────────────────────────────────────── */
|
|
242
|
+
const getPinningStyles = useCallback(
|
|
243
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
244
|
+
(header) => {
|
|
245
|
+
if (!columnPinnable)
|
|
246
|
+
return {};
|
|
247
|
+
const isPinned = header.column.getIsPinned();
|
|
248
|
+
if (!isPinned)
|
|
249
|
+
return {};
|
|
250
|
+
return {
|
|
251
|
+
position: 'sticky',
|
|
252
|
+
left: isPinned === 'left' ? `${header.getStart('left')}px` : undefined,
|
|
253
|
+
right: isPinned === 'right' ? `${header.getStart('right')}px` : undefined,
|
|
254
|
+
zIndex: 1,
|
|
255
|
+
backgroundColor: 'var(--color-card, #fff)',
|
|
256
|
+
};
|
|
257
|
+
}, [columnPinnable]);
|
|
258
|
+
const getCellPinningStyles = useCallback(
|
|
259
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
260
|
+
(cell) => {
|
|
261
|
+
if (!columnPinnable)
|
|
262
|
+
return {};
|
|
263
|
+
const isPinned = cell.column.getIsPinned();
|
|
264
|
+
if (!isPinned)
|
|
265
|
+
return {};
|
|
266
|
+
return {
|
|
267
|
+
position: 'sticky',
|
|
268
|
+
left: isPinned === 'left' ? `${cell.column.getStart('left')}px` : undefined,
|
|
269
|
+
right: isPinned === 'right' ? `${cell.column.getStart('right')}px` : undefined,
|
|
270
|
+
zIndex: 1,
|
|
271
|
+
backgroundColor: 'var(--color-card, #fff)',
|
|
272
|
+
};
|
|
273
|
+
}, [columnPinnable]);
|
|
274
|
+
/* ── Render ─────────────────────────────────────────────────────── */
|
|
275
|
+
return (_jsxs("div", { className: cn('w-full space-y-4', className), children: [(searchable || showColumnVisibility) && (_jsxs("div", { className: "flex flex-col gap-3 sm:flex-row sm:items-center sm:justify-between", children: [searchable && (_jsx(Input, { placeholder: searchPlaceholder, value: globalFilter, onChange: (e) => setGlobalFilter(e.target.value), className: "w-full bg-background shadow-mi-input sm:max-w-sm", size: "sm", leadingIcon: _jsxs("svg", { "aria-hidden": true, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: 2, className: "h-4 w-4", children: [_jsx("circle", { cx: "11", cy: "11", r: "8" }), _jsx("path", { strokeLinecap: "round", d: "m21 21-4.35-4.35" })] }) })), showColumnVisibility && (_jsx("div", { className: "sm:ml-auto", children: _jsx(ColumnVisibilityDropdown, { table: table }) }))] })), _jsx("div", { ref: tableScrollRef, className: cn('overflow-x-auto overflow-y-visible rounded-xl bg-card', virtualized && 'overflow-y-auto', (variant === 'bordered' || variant === 'card') && 'border border-border shadow-mi-card'), style: virtualized ? { maxHeight: virtualHeight } : undefined, children: _jsxs(Table, { variant: variant, headerTone: headerTone, className: cn((wide || columnFilterable || resizable) && 'min-w-[960px]'), ...(resizable ? { style: { width: table.getCenterTotalSize() } } : {}), children: [_jsx(TableHeader, { children: table.getHeaderGroups().map((headerGroup) => (_jsxs(Fragment, { children: [_jsx(TableRow, { children: headerGroup.headers.map((header) => (_jsxs(TableHead, { colSpan: header.colSpan, style: {
|
|
276
|
+
width: resizable ? header.getSize() : (header.getSize() !== 150 ? header.getSize() : undefined),
|
|
277
|
+
...getPinningStyles(header),
|
|
278
|
+
}, className: cn('h-12 whitespace-nowrap px-3 py-2 align-middle', resizable && 'relative', (header.column.id === 'select' || header.column.id === 'expand') && 'w-12 min-w-12', headerClassName), children: [header.isPlaceholder ? null : (_jsxs("div", { className: "flex min-w-0 items-center gap-1", children: [groupable && header.column.getCanGroup() && (_jsx("button", { type: "button", onClick: header.column.getToggleGroupingHandler(), className: cn('rounded p-0.5 hover:bg-muted transition-colors duration-150', 'focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring'), "aria-label": header.column.getIsGrouped()
|
|
279
|
+
? `Ungroup by ${header.column.id}`
|
|
280
|
+
: `Group by ${header.column.id}`, title: header.column.getIsGrouped()
|
|
281
|
+
? `Ungroup by ${header.column.id}`
|
|
282
|
+
: `Group by ${header.column.id}`, children: _jsx("svg", { "aria-hidden": true, viewBox: "0 0 16 16", fill: "none", stroke: "currentColor", strokeWidth: 1.5, className: cn('h-3.5 w-3.5', header.column.getIsGrouped()
|
|
283
|
+
? 'text-foreground'
|
|
284
|
+
: 'text-muted-foreground/50'), children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M2 4h12M2 8h8M2 12h4" }) }) })), flexRender(header.column.columnDef.header, header.getContext())] })), resizable && (_jsx("div", { onMouseDown: header.getResizeHandler(), onTouchStart: header.getResizeHandler(), onDoubleClick: () => header.column.resetSize(), role: "separator", "aria-orientation": "vertical", className: cn('absolute right-0 top-0 h-full w-1 cursor-col-resize select-none touch-none', 'hover:bg-primary/50 transition-colors duration-150', header.column.getIsResizing() && 'bg-primary') }))] }, header.id))) }), columnFilterable && (_jsx(TableRow, { className: "bg-muted/30 hover:bg-muted/30", children: headerGroup.headers.map((header) => (_jsx(TableHead, { colSpan: header.colSpan, style: {
|
|
285
|
+
width: resizable ? header.getSize() : (header.getSize() !== 150 ? header.getSize() : undefined),
|
|
286
|
+
...getPinningStyles(header),
|
|
287
|
+
}, className: cn('h-12 border-t border-border px-3 py-2 align-middle', (header.column.id === 'select' || header.column.id === 'expand') && 'w-12 min-w-12'), children: !header.isPlaceholder && header.column.getCanFilter() ? (_jsx(ColumnFilterInput, { column: header.column, faceted: faceted })) : null }, `${header.id}-filter`))) }))] }, headerGroup.id))) }), _jsxs(TableBody, { children: [rowPinnable &&
|
|
288
|
+
table.getTopRows().map((row) => (_jsx(Fragment, { children: _jsx(TableRow, { "data-state": row.getIsSelected() ? 'selected' : undefined, className: "bg-muted/30", children: row.getVisibleCells().map((cell) => (_jsx(TableCell, { style: getCellPinningStyles(cell), children: flexRender(cell.column.columnDef.cell, cell.getContext()) }, cell.id))) }) }, row.id))), regularRows.length ? (_jsxs(_Fragment, { children: [topVirtualPadding > 0 ? (_jsx(TableRow, { "aria-hidden": true, children: _jsx(TableCell, { colSpan: columns.length, style: { height: topVirtualPadding, padding: 0 } }) })) : null, rowsToRender.map((row) => (_jsxs(Fragment, { children: [_jsx(TableRow, { "data-state": row.getIsSelected() ? 'selected' : undefined, children: row.getVisibleCells().map((cell) => (_jsx(TableCell, { style: getCellPinningStyles(cell), children: groupable && cell.getIsGrouped() ? (_jsxs("button", { type: "button", onClick: row.getToggleExpandedHandler(), className: "inline-flex items-center gap-1 font-medium", children: [_jsx("svg", { "aria-hidden": true, viewBox: "0 0 16 16", fill: "none", stroke: "currentColor", strokeWidth: 2, className: cn('h-3.5 w-3.5 transition-transform duration-200', row.getIsExpanded() && 'rotate-90'), children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M6 4l4 4-4 4" }) }), flexRender(cell.column.columnDef.cell, cell.getContext()), ' ', _jsxs("span", { className: "text-muted-foreground text-xs", children: ["(", row.subRows.length, ")"] })] })) : groupable && cell.getIsAggregated() ? (flexRender(cell.column.columnDef.aggregatedCell ?? cell.column.columnDef.cell, cell.getContext())) : groupable && cell.getIsPlaceholder() ? null : (flexRender(cell.column.columnDef.cell, cell.getContext())) }, cell.id))) }), row.getIsExpanded() && renderSubComponent && !row.subRows.length && (_jsx(TableRow, { children: _jsx(TableCell, { colSpan: row.getVisibleCells().length, className: "p-0", children: renderSubComponent({ row: row }) }) }, `${row.id}-expanded`))] }, row.id))), bottomVirtualPadding > 0 ? (_jsx(TableRow, { "aria-hidden": true, children: _jsx(TableCell, { colSpan: columns.length, style: { height: bottomVirtualPadding, padding: 0 } }) })) : null] })) : (_jsx(TableRow, { children: _jsx(TableCell, { colSpan: columns.length, className: "h-24 text-center text-muted-foreground", children: emptyMessage }) })), rowPinnable &&
|
|
289
|
+
table.getBottomRows().map((row) => (_jsx(Fragment, { children: _jsx(TableRow, { "data-state": row.getIsSelected() ? 'selected' : undefined, className: "bg-muted/30", children: row.getVisibleCells().map((cell) => (_jsx(TableCell, { style: getCellPinningStyles(cell), children: flexRender(cell.column.columnDef.cell, cell.getContext()) }, cell.id))) }) }, row.id)))] })] }) }), paginated && (_jsxs("div", { className: "flex flex-col gap-3 text-sm sm:flex-row sm:items-center sm:justify-between", children: [_jsx("div", { className: "text-muted-foreground", children: selectable && (_jsxs("span", { children: [table.getFilteredSelectedRowModel().rows.length, " of", ' ', table.getFilteredRowModel().rows.length, " row(s) selected"] })) }), _jsxs("div", { className: "flex flex-col gap-3 sm:flex-row sm:items-center sm:gap-4", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "text-muted-foreground whitespace-nowrap", children: "Rows per page" }), _jsxs(Select, { value: String(table.getState().pagination.pageSize), onValueChange: (v) => table.setPageSize(Number(v)), children: [_jsx(SelectTrigger, { className: "h-7 w-[70px] text-sm" }), _jsx(SelectContent, { children: pageSizeOptions.map((size) => (_jsx(SelectItem, { value: String(size), children: size }, size))) })] })] }), _jsxs("span", { className: "text-muted-foreground whitespace-nowrap", children: ["Page ", pageIndex + 1, " of ", pageCount || 1] }), _jsxs("div", { className: "flex items-center gap-1", children: [_jsx(Button, { variant: "outline", size: "sm", onClick: () => table.previousPage(), disabled: !table.getCanPreviousPage(), children: "Previous" }), _jsx(Button, { variant: "outline", size: "sm", onClick: () => table.nextPage(), disabled: !table.getCanNextPage(), children: "Next" })] })] })] }))] }));
|
|
290
|
+
}
|
|
291
|
+
//# sourceMappingURL=DataTable.js.map
|