@eggspot/ui 0.0.2 → 0.0.3
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/Badge.d.ts +15 -0
- package/dist/components/Badge.d.ts.map +1 -0
- package/dist/components/Badge.js +29 -0
- package/dist/components/Badge.js.map +1 -0
- package/dist/components/Breadcrumb.d.ts +12 -0
- package/dist/components/Breadcrumb.d.ts.map +1 -0
- package/dist/components/Breadcrumb.js +28 -0
- package/dist/components/Breadcrumb.js.map +1 -0
- package/dist/components/Button.d.ts +53 -0
- package/dist/components/Button.d.ts.map +1 -0
- package/dist/components/Button.js +81 -0
- package/dist/components/Button.js.map +1 -0
- package/dist/components/Button.machine.d.ts +9 -0
- package/dist/components/Button.machine.d.ts.map +1 -0
- package/dist/components/Button.machine.js +50 -0
- package/dist/components/Button.machine.js.map +1 -0
- package/dist/components/Button.variants.d.ts +10 -0
- package/dist/components/Button.variants.d.ts.map +1 -0
- package/dist/components/Button.variants.js +214 -0
- package/dist/components/Button.variants.js.map +1 -0
- package/dist/components/ButtonGroup.d.ts +9 -0
- package/dist/components/ButtonGroup.d.ts.map +1 -0
- package/dist/components/ButtonGroup.js +23 -0
- package/dist/components/ButtonGroup.js.map +1 -0
- package/dist/components/Calendar.d.ts +24 -0
- package/dist/components/Calendar.d.ts.map +1 -0
- package/dist/components/Calendar.js +64 -0
- package/dist/components/Calendar.js.map +1 -0
- package/dist/components/Calendar.utils.d.ts +6 -0
- package/dist/components/Calendar.utils.d.ts.map +1 -0
- package/dist/components/Calendar.utils.js +17 -0
- package/dist/components/Calendar.utils.js.map +1 -0
- package/dist/components/Card.d.ts +8 -0
- package/dist/components/Card.d.ts.map +1 -0
- package/dist/components/Card.js +19 -0
- package/dist/components/Card.js.map +1 -0
- package/dist/components/Checkbox.d.ts +36 -0
- package/dist/components/Checkbox.d.ts.map +1 -0
- package/dist/components/Checkbox.js +55 -0
- package/dist/components/Checkbox.js.map +1 -0
- package/dist/components/Collapsible.d.ts +20 -0
- package/dist/components/Collapsible.d.ts.map +1 -0
- package/dist/components/Collapsible.js +15 -0
- package/dist/components/Collapsible.js.map +1 -0
- package/dist/components/ConfirmDialog.d.ts +35 -0
- package/dist/components/ConfirmDialog.d.ts.map +1 -0
- package/dist/components/ConfirmDialog.js +81 -0
- package/dist/components/ConfirmDialog.js.map +1 -0
- package/dist/components/CopyButton.d.ts +67 -0
- package/dist/components/CopyButton.d.ts.map +1 -0
- package/dist/components/CopyButton.js +51 -0
- package/dist/components/CopyButton.js.map +1 -0
- package/dist/components/DashboardLayout/DashboardLayout.d.ts +3 -0
- package/dist/components/DashboardLayout/DashboardLayout.d.ts.map +1 -0
- package/dist/components/DashboardLayout/DashboardLayout.js +38 -0
- package/dist/components/DashboardLayout/DashboardLayout.js.map +1 -0
- package/dist/components/DashboardLayout/DashboardLayoutContent.d.ts +9 -0
- package/dist/components/DashboardLayout/DashboardLayoutContent.d.ts.map +1 -0
- package/dist/components/DashboardLayout/DashboardLayoutContent.js +10 -0
- package/dist/components/DashboardLayout/DashboardLayoutContent.js.map +1 -0
- package/dist/components/DashboardLayout/index.d.ts +4 -0
- package/dist/components/DashboardLayout/index.d.ts.map +1 -0
- package/dist/components/DashboardLayout/index.js +3 -0
- package/dist/components/DashboardLayout/index.js.map +1 -0
- package/dist/components/DashboardLayout/types.d.ts +37 -0
- package/dist/components/DashboardLayout/types.d.ts.map +1 -0
- package/dist/components/DashboardLayout/types.js +2 -0
- package/dist/components/DashboardLayout/types.js.map +1 -0
- package/dist/components/DataTable/DataTable.d.ts +9 -0
- package/dist/components/DataTable/DataTable.d.ts.map +1 -0
- package/dist/components/DataTable/DataTable.js +271 -0
- package/dist/components/DataTable/DataTable.js.map +1 -0
- package/dist/components/DataTable/DataTableColumnHeader.d.ts +11 -0
- package/dist/components/DataTable/DataTableColumnHeader.d.ts.map +1 -0
- package/dist/components/DataTable/DataTableColumnHeader.js +26 -0
- package/dist/components/DataTable/DataTableColumnHeader.js.map +1 -0
- package/dist/components/DataTable/DataTableDisplaySettings.d.ts +8 -0
- package/dist/components/DataTable/DataTableDisplaySettings.d.ts.map +1 -0
- package/dist/components/DataTable/DataTableDisplaySettings.js +88 -0
- package/dist/components/DataTable/DataTableDisplaySettings.js.map +1 -0
- package/dist/components/DataTable/DataTableFloatingBar.d.ts +8 -0
- package/dist/components/DataTable/DataTableFloatingBar.d.ts.map +1 -0
- package/dist/components/DataTable/DataTableFloatingBar.js +11 -0
- package/dist/components/DataTable/DataTableFloatingBar.js.map +1 -0
- package/dist/components/DataTable/DataTablePagination.d.ts +11 -0
- package/dist/components/DataTable/DataTablePagination.d.ts.map +1 -0
- package/dist/components/DataTable/DataTablePagination.js +68 -0
- package/dist/components/DataTable/DataTablePagination.js.map +1 -0
- package/dist/components/DataTable/DataTableStates.d.ts +13 -0
- package/dist/components/DataTable/DataTableStates.d.ts.map +1 -0
- package/dist/components/DataTable/DataTableStates.js +17 -0
- package/dist/components/DataTable/DataTableStates.js.map +1 -0
- package/dist/components/DataTable/DataTableToolbarContainer.d.ts +7 -0
- package/dist/components/DataTable/DataTableToolbarContainer.d.ts.map +1 -0
- package/dist/components/DataTable/DataTableToolbarContainer.js +7 -0
- package/dist/components/DataTable/DataTableToolbarContainer.js.map +1 -0
- package/dist/components/DataTable/hooks/use-data-table-settings.d.ts +19 -0
- package/dist/components/DataTable/hooks/use-data-table-settings.d.ts.map +1 -0
- package/dist/components/DataTable/hooks/use-data-table-settings.js +70 -0
- package/dist/components/DataTable/hooks/use-data-table-settings.js.map +1 -0
- package/dist/components/DataTable/index.d.ts +4 -0
- package/dist/components/DataTable/index.d.ts.map +1 -0
- package/dist/components/DataTable/index.js +3 -0
- package/dist/components/DataTable/index.js.map +1 -0
- package/dist/components/DataTable/types/data-table.d.ts +76 -0
- package/dist/components/DataTable/types/data-table.d.ts.map +1 -0
- package/dist/components/DataTable/types/data-table.js +2 -0
- package/dist/components/DataTable/types/data-table.js.map +1 -0
- package/dist/components/DatePicker.d.ts +19 -0
- package/dist/components/DatePicker.d.ts.map +1 -0
- package/dist/components/DatePicker.js +49 -0
- package/dist/components/DatePicker.js.map +1 -0
- package/dist/components/DatePicker.utils.d.ts +3 -0
- package/dist/components/DatePicker.utils.d.ts.map +1 -0
- package/dist/components/DatePicker.utils.js +23 -0
- package/dist/components/DatePicker.utils.js.map +1 -0
- package/dist/components/Datefield.d.ts +25 -0
- package/dist/components/Datefield.d.ts.map +1 -0
- package/dist/components/Datefield.js +29 -0
- package/dist/components/Datefield.js.map +1 -0
- package/dist/components/Datefield.utils.d.ts +3 -0
- package/dist/components/Datefield.utils.d.ts.map +1 -0
- package/dist/components/Datefield.utils.js +11 -0
- package/dist/components/Datefield.utils.js.map +1 -0
- package/dist/components/Dialog.d.ts +21 -0
- package/dist/components/Dialog.d.ts.map +1 -0
- package/dist/components/Dialog.js +23 -0
- package/dist/components/Dialog.js.map +1 -0
- package/dist/components/Field.d.ts +10 -0
- package/dist/components/Field.d.ts.map +1 -0
- package/dist/components/Field.js +32 -0
- package/dist/components/Field.js.map +1 -0
- package/dist/components/Filter/Filter.d.ts +4 -0
- package/dist/components/Filter/Filter.d.ts.map +1 -0
- package/dist/components/Filter/Filter.js +8 -0
- package/dist/components/Filter/Filter.js.map +1 -0
- package/dist/components/Filter/Filter.store.d.ts +13 -0
- package/dist/components/Filter/Filter.store.d.ts.map +1 -0
- package/dist/components/Filter/Filter.store.js +61 -0
- package/dist/components/Filter/Filter.store.js.map +1 -0
- package/dist/components/Filter/Filter.types.d.ts +66 -0
- package/dist/components/Filter/Filter.types.d.ts.map +1 -0
- package/dist/components/Filter/Filter.types.js +15 -0
- package/dist/components/Filter/Filter.types.js.map +1 -0
- package/dist/components/Filter/FilterBar.d.ts +7 -0
- package/dist/components/Filter/FilterBar.d.ts.map +1 -0
- package/dist/components/Filter/FilterBar.js +28 -0
- package/dist/components/Filter/FilterBar.js.map +1 -0
- package/dist/components/Filter/FilterBuilder.d.ts +3 -0
- package/dist/components/Filter/FilterBuilder.d.ts.map +1 -0
- package/dist/components/Filter/FilterBuilder.js +47 -0
- package/dist/components/Filter/FilterBuilder.js.map +1 -0
- package/dist/components/Filter/FilterField/DateModeRowValue.d.ts +5 -0
- package/dist/components/Filter/FilterField/DateModeRowValue.d.ts.map +1 -0
- package/dist/components/Filter/FilterField/DateModeRowValue.js +150 -0
- package/dist/components/Filter/FilterField/DateModeRowValue.js.map +1 -0
- package/dist/components/Filter/FilterField/FilterAsyncSelect.d.ts +13 -0
- package/dist/components/Filter/FilterField/FilterAsyncSelect.d.ts.map +1 -0
- package/dist/components/Filter/FilterField/FilterAsyncSelect.js +62 -0
- package/dist/components/Filter/FilterField/FilterAsyncSelect.js.map +1 -0
- package/dist/components/Filter/FilterField/FilterDateMode.d.ts +2 -0
- package/dist/components/Filter/FilterField/FilterDateMode.d.ts.map +1 -0
- package/dist/components/Filter/FilterField/FilterDateMode.js +167 -0
- package/dist/components/Filter/FilterField/FilterDateMode.js.map +1 -0
- package/dist/components/Filter/FilterField/FilterDateRange.d.ts +7 -0
- package/dist/components/Filter/FilterField/FilterDateRange.d.ts.map +1 -0
- package/dist/components/Filter/FilterField/FilterDateRange.js +60 -0
- package/dist/components/Filter/FilterField/FilterDateRange.js.map +1 -0
- package/dist/components/Filter/FilterField/FilterSelect.d.ts +12 -0
- package/dist/components/Filter/FilterField/FilterSelect.d.ts.map +1 -0
- package/dist/components/Filter/FilterField/FilterSelect.js +72 -0
- package/dist/components/Filter/FilterField/FilterSelect.js.map +1 -0
- package/dist/components/Filter/FilterField/FilterSingleDate.d.ts +8 -0
- package/dist/components/Filter/FilterField/FilterSingleDate.d.ts.map +1 -0
- package/dist/components/Filter/FilterField/FilterSingleDate.js +102 -0
- package/dist/components/Filter/FilterField/FilterSingleDate.js.map +1 -0
- package/dist/components/Filter/FilterField/OptionItem.d.ts +10 -0
- package/dist/components/Filter/FilterField/OptionItem.d.ts.map +1 -0
- package/dist/components/Filter/FilterField/OptionItem.js +20 -0
- package/dist/components/Filter/FilterField/OptionItem.js.map +1 -0
- package/dist/components/Filter/FilterField/index.d.ts +7 -0
- package/dist/components/Filter/FilterField/index.d.ts.map +1 -0
- package/dist/components/Filter/FilterField/index.js +7 -0
- package/dist/components/Filter/FilterField/index.js.map +1 -0
- package/dist/components/Filter/FilterRow.d.ts +7 -0
- package/dist/components/Filter/FilterRow.d.ts.map +1 -0
- package/dist/components/Filter/FilterRow.js +152 -0
- package/dist/components/Filter/FilterRow.js.map +1 -0
- package/dist/components/Filter/index.d.ts +7 -0
- package/dist/components/Filter/index.d.ts.map +1 -0
- package/dist/components/Filter/index.js +6 -0
- package/dist/components/Filter/index.js.map +1 -0
- package/dist/components/Form.d.ts +32 -0
- package/dist/components/Form.d.ts.map +1 -0
- package/dist/components/Form.js +82 -0
- package/dist/components/Form.js.map +1 -0
- package/dist/components/Heading.d.ts +10 -0
- package/dist/components/Heading.d.ts.map +1 -0
- package/dist/components/Heading.js +27 -0
- package/dist/components/Heading.js.map +1 -0
- package/dist/components/Input.d.ts +43 -0
- package/dist/components/Input.d.ts.map +1 -0
- package/dist/components/Input.js +58 -0
- package/dist/components/Input.js.map +1 -0
- package/dist/components/InputOTP.d.ts +12 -0
- package/dist/components/InputOTP.d.ts.map +1 -0
- package/dist/components/InputOTP.js +24 -0
- package/dist/components/InputOTP.js.map +1 -0
- package/dist/components/Label.d.ts +9 -0
- package/dist/components/Label.d.ts.map +1 -0
- package/dist/components/Label.js +19 -0
- package/dist/components/Label.js.map +1 -0
- package/dist/components/Layout.d.ts +47 -0
- package/dist/components/Layout.d.ts.map +1 -0
- package/dist/components/Layout.js +78 -0
- package/dist/components/Layout.js.map +1 -0
- package/dist/components/ListBox.d.ts +8 -0
- package/dist/components/ListBox.d.ts.map +1 -0
- package/dist/components/ListBox.js +28 -0
- package/dist/components/ListBox.js.map +1 -0
- package/dist/components/Menu.d.ts +19 -0
- package/dist/components/Menu.d.ts.map +1 -0
- package/dist/components/Menu.js +29 -0
- package/dist/components/Menu.js.map +1 -0
- package/dist/components/NativeSelect.d.ts +10 -0
- package/dist/components/NativeSelect.d.ts.map +1 -0
- package/dist/components/NativeSelect.js +36 -0
- package/dist/components/NativeSelect.js.map +1 -0
- package/dist/components/NumberInput.d.ts +12 -0
- package/dist/components/NumberInput.d.ts.map +1 -0
- package/dist/components/NumberInput.js +25 -0
- package/dist/components/NumberInput.js.map +1 -0
- package/dist/components/Popover.d.ts +9 -0
- package/dist/components/Popover.d.ts.map +1 -0
- package/dist/components/Popover.js +17 -0
- package/dist/components/Popover.js.map +1 -0
- package/dist/components/Provider.d.ts +10 -0
- package/dist/components/Provider.d.ts.map +1 -0
- package/dist/components/Provider.js +11 -0
- package/dist/components/Provider.js.map +1 -0
- package/dist/components/RadioGroup.d.ts +37 -0
- package/dist/components/RadioGroup.d.ts.map +1 -0
- package/dist/components/RadioGroup.js +61 -0
- package/dist/components/RadioGroup.js.map +1 -0
- package/dist/components/Resizable.d.ts +25 -0
- package/dist/components/Resizable.d.ts.map +1 -0
- package/dist/components/Resizable.js +19 -0
- package/dist/components/Resizable.js.map +1 -0
- package/dist/components/ScrollArea.d.ts +6 -0
- package/dist/components/ScrollArea.d.ts.map +1 -0
- package/dist/components/ScrollArea.js +14 -0
- package/dist/components/ScrollArea.js.map +1 -0
- package/dist/components/Select.d.ts +88 -0
- package/dist/components/Select.d.ts.map +1 -0
- package/dist/components/Select.js +174 -0
- package/dist/components/Select.js.map +1 -0
- package/dist/components/Select.utils.d.ts +13 -0
- package/dist/components/Select.utils.d.ts.map +1 -0
- package/dist/components/Select.utils.js +41 -0
- package/dist/components/Select.utils.js.map +1 -0
- package/dist/components/Separator.d.ts +4 -0
- package/dist/components/Separator.d.ts.map +1 -0
- package/dist/components/Separator.js +7 -0
- package/dist/components/Separator.js.map +1 -0
- package/dist/components/Sheet.d.ts +19 -0
- package/dist/components/Sheet.d.ts.map +1 -0
- package/dist/components/Sheet.js +24 -0
- package/dist/components/Sheet.js.map +1 -0
- package/dist/components/Sidebar/LinkItem.d.ts +34 -0
- package/dist/components/Sidebar/LinkItem.d.ts.map +1 -0
- package/dist/components/Sidebar/LinkItem.js +19 -0
- package/dist/components/Sidebar/LinkItem.js.map +1 -0
- package/dist/components/Sidebar/PageTree.d.ts +46 -0
- package/dist/components/Sidebar/PageTree.d.ts.map +1 -0
- package/dist/components/Sidebar/PageTree.js +46 -0
- package/dist/components/Sidebar/PageTree.js.map +1 -0
- package/dist/components/Sidebar/Sidebar.d.ts +94 -0
- package/dist/components/Sidebar/Sidebar.d.ts.map +1 -0
- package/dist/components/Sidebar/Sidebar.js +328 -0
- package/dist/components/Sidebar/Sidebar.js.map +1 -0
- package/dist/components/Sidebar/SidebarNavTree.d.ts +26 -0
- package/dist/components/Sidebar/SidebarNavTree.d.ts.map +1 -0
- package/dist/components/Sidebar/SidebarNavTree.js +32 -0
- package/dist/components/Sidebar/SidebarNavTree.js.map +1 -0
- package/dist/components/Sidebar/Tabs.d.ts +27 -0
- package/dist/components/Sidebar/Tabs.d.ts.map +1 -0
- package/dist/components/Sidebar/Tabs.js +49 -0
- package/dist/components/Sidebar/Tabs.js.map +1 -0
- package/dist/components/Sidebar/index.d.ts +6 -0
- package/dist/components/Sidebar/index.d.ts.map +1 -0
- package/dist/components/Sidebar/index.js +22 -0
- package/dist/components/Sidebar/index.js.map +1 -0
- package/dist/components/Sonner.d.ts +16 -0
- package/dist/components/Sonner.d.ts.map +1 -0
- package/dist/components/Sonner.js +38 -0
- package/dist/components/Sonner.js.map +1 -0
- package/dist/components/Spinner.d.ts +3 -0
- package/dist/components/Spinner.d.ts.map +1 -0
- package/dist/components/Spinner.js +7 -0
- package/dist/components/Spinner.js.map +1 -0
- package/dist/components/Switch.d.ts +4 -0
- package/dist/components/Switch.d.ts.map +1 -0
- package/dist/components/Switch.js +19 -0
- package/dist/components/Switch.js.map +1 -0
- package/dist/components/Text.d.ts +10 -0
- package/dist/components/Text.d.ts.map +1 -0
- package/dist/components/Text.js +22 -0
- package/dist/components/Text.js.map +1 -0
- package/dist/components/Tooltip.d.ts +8 -0
- package/dist/components/Tooltip.d.ts.map +1 -0
- package/dist/components/Tooltip.js +24 -0
- package/dist/components/Tooltip.js.map +1 -0
- package/dist/components/Virtualizer.d.ts +8 -0
- package/dist/components/Virtualizer.d.ts.map +1 -0
- package/dist/components/Virtualizer.js +8 -0
- package/dist/components/Virtualizer.js.map +1 -0
- package/dist/consts/config.d.ts +3 -0
- package/dist/consts/config.d.ts.map +1 -0
- package/dist/consts/config.js +3 -0
- package/dist/consts/config.js.map +1 -0
- package/dist/hooks/use-mobile.d.ts +6 -0
- package/dist/hooks/use-mobile.d.ts.map +1 -0
- package/dist/hooks/use-mobile.js +16 -0
- package/dist/hooks/use-mobile.js.map +1 -0
- package/dist/lib/utils.d.ts +4 -0
- package/dist/lib/utils.d.ts.map +1 -0
- package/dist/lib/utils.js +9 -0
- package/dist/lib/utils.js.map +1 -0
- package/package.json +53 -5
- package/eslint.config.js +0 -41
- package/resolve-catalog.js +0 -61
- package/src/components/Button.machine.tsx +0 -50
- package/src/components/Button.tsx +0 -249
- package/src/components/Button.variants.tsx +0 -186
- package/src/components/ButtonGroup.tsx +0 -56
- package/src/components/Calendar.tsx +0 -275
- package/src/components/Calendar.utils.tsx +0 -22
- package/src/components/Checkbox.tsx +0 -199
- package/src/components/ConfirmDialog.tsx +0 -183
- package/src/components/DashboardLayout/DashboardLayout.tsx +0 -348
- package/src/components/DashboardLayout/SidebarNav.tsx +0 -509
- package/src/components/DashboardLayout/index.ts +0 -33
- package/src/components/DataTable/DataTable.tsx +0 -557
- package/src/components/DataTable/DataTableColumnHeader.tsx +0 -122
- package/src/components/DataTable/DataTableDisplaySettings.tsx +0 -265
- package/src/components/DataTable/DataTableFloatingBar.tsx +0 -44
- package/src/components/DataTable/DataTablePagination.tsx +0 -168
- package/src/components/DataTable/DataTableStates.tsx +0 -69
- package/src/components/DataTable/DataTableToolbarContainer.tsx +0 -47
- package/src/components/DataTable/hooks/use-data-table-settings.ts +0 -101
- package/src/components/DataTable/index.ts +0 -7
- package/src/components/DataTable/types/data-table.ts +0 -97
- package/src/components/DatePicker.tsx +0 -213
- package/src/components/DatePicker.utils.tsx +0 -38
- package/src/components/Datefield.tsx +0 -109
- package/src/components/Datefield.utils.ts +0 -10
- package/src/components/Dialog.tsx +0 -167
- package/src/components/Field.tsx +0 -49
- package/src/components/Filter/Filter.store.tsx +0 -122
- package/src/components/Filter/Filter.tsx +0 -11
- package/src/components/Filter/Filter.types.ts +0 -107
- package/src/components/Filter/FilterBar.tsx +0 -38
- package/src/components/Filter/FilterBuilder.tsx +0 -158
- package/src/components/Filter/FilterField/DateModeRowValue.tsx +0 -250
- package/src/components/Filter/FilterField/FilterAsyncSelect.tsx +0 -191
- package/src/components/Filter/FilterField/FilterDateMode.tsx +0 -241
- package/src/components/Filter/FilterField/FilterDateRange.tsx +0 -169
- package/src/components/Filter/FilterField/FilterSelect.tsx +0 -208
- package/src/components/Filter/FilterField/FilterSingleDate.tsx +0 -277
- package/src/components/Filter/FilterField/OptionItem.tsx +0 -112
- package/src/components/Filter/FilterField/index.ts +0 -6
- package/src/components/Filter/FilterRow.tsx +0 -527
- package/src/components/Filter/index.ts +0 -17
- package/src/components/Form.tsx +0 -195
- package/src/components/Heading.tsx +0 -41
- package/src/components/Input.tsx +0 -221
- package/src/components/InputOTP.tsx +0 -78
- package/src/components/Label.tsx +0 -65
- package/src/components/Layout.tsx +0 -129
- package/src/components/ListBox.tsx +0 -97
- package/src/components/Menu.tsx +0 -152
- package/src/components/NativeSelect.tsx +0 -77
- package/src/components/NumberInput.tsx +0 -114
- package/src/components/Popover.tsx +0 -44
- package/src/components/Provider.tsx +0 -22
- package/src/components/RadioGroup.tsx +0 -191
- package/src/components/Resizable.tsx +0 -71
- package/src/components/ScrollArea.tsx +0 -57
- package/src/components/Select.tsx +0 -626
- package/src/components/Select.utils.tsx +0 -64
- package/src/components/Separator.tsx +0 -25
- package/src/components/Sheet.tsx +0 -147
- package/src/components/Sonner.tsx +0 -96
- package/src/components/Spinner.tsx +0 -30
- package/src/components/Switch.tsx +0 -51
- package/src/components/Text.tsx +0 -35
- package/src/components/Tooltip.tsx +0 -58
- package/src/consts/config.ts +0 -2
- package/src/hooks/.gitkeep +0 -0
- package/src/lib/utils.ts +0 -10
- package/tsconfig.json +0 -27
- package/tsconfig.lint.json +0 -8
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import { type VariantProps } from "class-variance-authority";
|
|
3
|
+
declare const colors: readonly ["accent", "gray", "red", "blue", "grass", "amber"];
|
|
4
|
+
type Color = (typeof colors)[number];
|
|
5
|
+
declare const badgeVariants: (props?: ({
|
|
6
|
+
size?: "sm" | "md" | "lg" | null | undefined;
|
|
7
|
+
} & import("class-variance-authority/dist/types").ClassProp) | undefined) => string;
|
|
8
|
+
type BadgeVariantProps = VariantProps<typeof badgeVariants>;
|
|
9
|
+
declare function Badge({ className, asChild, color, size, ...props }: React.ComponentProps<"span"> & {
|
|
10
|
+
asChild?: boolean;
|
|
11
|
+
color?: Color;
|
|
12
|
+
} & BadgeVariantProps): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
export { Badge, badgeVariants };
|
|
14
|
+
export type { BadgeVariantProps };
|
|
15
|
+
//# sourceMappingURL=Badge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Badge.d.ts","sourceRoot":"","sources":["../../src/components/Badge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAG9B,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAEjE,QAAA,MAAM,MAAM,8DAA+D,CAAA;AAE3E,KAAK,KAAK,GAAG,CAAC,OAAO,MAAM,CAAC,CAAC,MAAM,CAAC,CAAA;AAEpC,QAAA,MAAM,aAAa;;mFAiBlB,CAAA;AAED,KAAK,iBAAiB,GAAG,YAAY,CAAC,OAAO,aAAa,CAAC,CAAA;AAE3D,iBAAS,KAAK,CAAC,EACb,SAAS,EACT,OAAe,EACf,KAAgB,EAChB,IAAW,EACX,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC,GAAG;IAChC,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,KAAK,CAAC,EAAE,KAAK,CAAA;CACd,GAAG,iBAAiB,2CAcpB;AAED,OAAO,EAAE,KAAK,EAAE,aAAa,EAAE,CAAA;AAC/B,YAAY,EAAE,iBAAiB,EAAE,CAAA"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from "@eggspot/ui/lib/utils";
|
|
3
|
+
import { Slot } from "@radix-ui/react-slot";
|
|
4
|
+
import { cva } from "class-variance-authority";
|
|
5
|
+
const colors = ["accent", "gray", "red", "blue", "grass", "amber"];
|
|
6
|
+
const badgeVariants = cva([
|
|
7
|
+
"inline-flex w-fit shrink-0 items-center justify-center gap-1 overflow-hidden rounded-md font-medium whitespace-nowrap",
|
|
8
|
+
"[&>svg]:pointer-events-none",
|
|
9
|
+
], {
|
|
10
|
+
variants: {
|
|
11
|
+
size: {
|
|
12
|
+
sm: "px-1 py-0 text-[10px] [&>svg]:size-2.5",
|
|
13
|
+
md: "px-1.5 py-0.5 text-xs [&>svg]:size-3",
|
|
14
|
+
lg: "px-2 py-1 text-[13px] [&>svg]:size-3.5",
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
defaultVariants: {
|
|
18
|
+
size: "md",
|
|
19
|
+
},
|
|
20
|
+
});
|
|
21
|
+
function Badge({ className, asChild = false, color = "accent", size = "md", ...props }) {
|
|
22
|
+
const Comp = asChild ? Slot : "span";
|
|
23
|
+
return (_jsx(Comp, { "data-slot": "badge", className: cn(badgeVariants({ size }), className), style: {
|
|
24
|
+
backgroundColor: `oklch(from var(--${color}-9) l c h / 0.15)`,
|
|
25
|
+
color: `var(--${color}-11)`,
|
|
26
|
+
}, ...props }));
|
|
27
|
+
}
|
|
28
|
+
export { Badge, badgeVariants };
|
|
29
|
+
//# sourceMappingURL=Badge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Badge.js","sourceRoot":"","sources":["../../src/components/Badge.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,EAAE,EAAE,MAAM,uBAAuB,CAAA;AAC1C,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAC3C,OAAO,EAAE,GAAG,EAAqB,MAAM,0BAA0B,CAAA;AAEjE,MAAM,MAAM,GAAG,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAU,CAAA;AAI3E,MAAM,aAAa,GAAG,GAAG,CACvB;IACE,uHAAuH;IACvH,6BAA6B;CAC9B,EACD;IACE,QAAQ,EAAE;QACR,IAAI,EAAE;YACJ,EAAE,EAAE,wCAAwC;YAC5C,EAAE,EAAE,sCAAsC;YAC1C,EAAE,EAAE,wCAAwC;SAC7C;KACF;IACD,eAAe,EAAE;QACf,IAAI,EAAE,IAAI;KACX;CACF,CACF,CAAA;AAID,SAAS,KAAK,CAAC,EACb,SAAS,EACT,OAAO,GAAG,KAAK,EACf,KAAK,GAAG,QAAQ,EAChB,IAAI,GAAG,IAAI,EACX,GAAG,KAAK,EAIW;IACnB,MAAM,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAA;IAEpC,OAAO,CACL,KAAC,IAAI,iBACO,OAAO,EACjB,SAAS,EAAE,EAAE,CAAC,aAAa,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,SAAS,CAAC,EACjD,KAAK,EAAE;YACL,eAAe,EAAE,oBAAoB,KAAK,mBAAmB;YAC7D,KAAK,EAAE,SAAS,KAAK,MAAM;SAC5B,KACG,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,OAAO,EAAE,KAAK,EAAE,aAAa,EAAE,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
declare function Breadcrumb({ ...props }: React.ComponentProps<"nav">): import("react/jsx-runtime").JSX.Element;
|
|
3
|
+
declare function BreadcrumbList({ className, ...props }: React.ComponentProps<"ol">): import("react/jsx-runtime").JSX.Element;
|
|
4
|
+
declare function BreadcrumbItem({ className, ...props }: React.ComponentProps<"li">): import("react/jsx-runtime").JSX.Element;
|
|
5
|
+
declare function BreadcrumbLink({ asChild, className, ...props }: React.ComponentProps<"a"> & {
|
|
6
|
+
asChild?: boolean;
|
|
7
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
declare function BreadcrumbPage({ className, ...props }: React.ComponentProps<"span">): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
declare function BreadcrumbSeparator({ children, className, ...props }: React.ComponentProps<"li">): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
declare function BreadcrumbEllipsis({ className, ...props }: React.ComponentProps<"span">): import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
export { Breadcrumb, BreadcrumbList, BreadcrumbItem, BreadcrumbLink, BreadcrumbPage, BreadcrumbSeparator, BreadcrumbEllipsis, };
|
|
12
|
+
//# sourceMappingURL=Breadcrumb.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Breadcrumb.d.ts","sourceRoot":"","sources":["../../src/components/Breadcrumb.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAK9B,iBAAS,UAAU,CAAC,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,2CAE5D;AAED,iBAAS,cAAc,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,2CAW1E;AAED,iBAAS,cAAc,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,2CAW1E;AAED,iBAAS,cAAc,CAAC,EACtB,OAAO,EACP,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG;IAC7B,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB,2CAUA;AAED,iBAAS,cAAc,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC,2CAW5E;AAED,iBAAS,mBAAmB,CAAC,EAC3B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,2CAY5B;AAED,iBAAS,kBAAkB,CAAC,EAC1B,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC,2CAa9B;AAED,OAAO,EACL,UAAU,EACV,cAAc,EACd,cAAc,EACd,cAAc,EACd,cAAc,EACd,mBAAmB,EACnB,kBAAkB,GACnB,CAAA"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from "@eggspot/ui/lib/utils";
|
|
3
|
+
import { Slot } from "@radix-ui/react-slot";
|
|
4
|
+
import { ChevronRight, MoreHorizontal } from "lucide-react";
|
|
5
|
+
function Breadcrumb({ ...props }) {
|
|
6
|
+
return _jsx("nav", { "aria-label": "breadcrumb", "data-slot": "breadcrumb", ...props });
|
|
7
|
+
}
|
|
8
|
+
function BreadcrumbList({ className, ...props }) {
|
|
9
|
+
return (_jsx("ol", { "data-slot": "breadcrumb-list", className: cn("text-gray-11 wrap-break-words flex flex-wrap items-center gap-1.5 sm:gap-2.5", className), ...props }));
|
|
10
|
+
}
|
|
11
|
+
function BreadcrumbItem({ className, ...props }) {
|
|
12
|
+
return (_jsx("li", { "data-slot": "breadcrumb-item", className: cn("inline-flex items-center gap-1.5 text-sm font-medium", className), ...props }));
|
|
13
|
+
}
|
|
14
|
+
function BreadcrumbLink({ asChild, className, ...props }) {
|
|
15
|
+
const Comp = asChild ? Slot : "a";
|
|
16
|
+
return (_jsx(Comp, { "data-slot": "breadcrumb-link", className: cn("hover:text-gray-12 transition-colors", className), ...props }));
|
|
17
|
+
}
|
|
18
|
+
function BreadcrumbPage({ className, ...props }) {
|
|
19
|
+
return (_jsx("span", { "data-slot": "breadcrumb-page", role: "link", "aria-disabled": "true", "aria-current": "page", className: cn("text-gray-12", className), ...props }));
|
|
20
|
+
}
|
|
21
|
+
function BreadcrumbSeparator({ children, className, ...props }) {
|
|
22
|
+
return (_jsx("li", { "data-slot": "breadcrumb-separator", role: "presentation", "aria-hidden": "true", className: cn("opacity-50 [&>svg]:size-3.5", className), ...props, children: children ?? _jsx(ChevronRight, { strokeWidth: 2.5 }) }));
|
|
23
|
+
}
|
|
24
|
+
function BreadcrumbEllipsis({ className, ...props }) {
|
|
25
|
+
return (_jsxs("span", { "data-slot": "breadcrumb-ellipsis", role: "presentation", "aria-hidden": "true", className: cn("flex size-9 items-center justify-center", className), ...props, children: [_jsx(MoreHorizontal, { className: "size-4" }), _jsx("span", { className: "sr-only", children: "More" })] }));
|
|
26
|
+
}
|
|
27
|
+
export { Breadcrumb, BreadcrumbList, BreadcrumbItem, BreadcrumbLink, BreadcrumbPage, BreadcrumbSeparator, BreadcrumbEllipsis, };
|
|
28
|
+
//# sourceMappingURL=Breadcrumb.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Breadcrumb.js","sourceRoot":"","sources":["../../src/components/Breadcrumb.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,EAAE,EAAE,MAAM,uBAAuB,CAAA;AAC1C,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAC3C,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAE3D,SAAS,UAAU,CAAC,EAAE,GAAG,KAAK,EAA+B;IAC3D,OAAO,4BAAgB,YAAY,eAAW,YAAY,KAAK,KAAK,GAAI,CAAA;AAC1E,CAAC;AAED,SAAS,cAAc,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAA8B;IACzE,OAAO,CACL,0BACY,iBAAiB,EAC3B,SAAS,EAAE,EAAE,CACX,8EAA8E,EAC9E,SAAS,CACV,KACG,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,SAAS,cAAc,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAA8B;IACzE,OAAO,CACL,0BACY,iBAAiB,EAC3B,SAAS,EAAE,EAAE,CACX,sDAAsD,EACtD,SAAS,CACV,KACG,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,SAAS,cAAc,CAAC,EACtB,OAAO,EACP,SAAS,EACT,GAAG,KAAK,EAGT;IACC,MAAM,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAA;IAEjC,OAAO,CACL,KAAC,IAAI,iBACO,iBAAiB,EAC3B,SAAS,EAAE,EAAE,CAAC,sCAAsC,EAAE,SAAS,CAAC,KAC5D,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,SAAS,cAAc,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAgC;IAC3E,OAAO,CACL,4BACY,iBAAiB,EAC3B,IAAI,EAAC,MAAM,mBACG,MAAM,kBACP,MAAM,EACnB,SAAS,EAAE,EAAE,CAAC,cAAc,EAAE,SAAS,CAAC,KACpC,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,SAAS,mBAAmB,CAAC,EAC3B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACmB;IAC3B,OAAO,CACL,0BACY,sBAAsB,EAChC,IAAI,EAAC,cAAc,iBACP,MAAM,EAClB,SAAS,EAAE,EAAE,CAAC,6BAA6B,EAAE,SAAS,CAAC,KACnD,KAAK,YAER,QAAQ,IAAI,KAAC,YAAY,IAAC,WAAW,EAAE,GAAG,GAAI,GAC5C,CACN,CAAA;AACH,CAAC;AAED,SAAS,kBAAkB,CAAC,EAC1B,SAAS,EACT,GAAG,KAAK,EACqB;IAC7B,OAAO,CACL,6BACY,qBAAqB,EAC/B,IAAI,EAAC,cAAc,iBACP,MAAM,EAClB,SAAS,EAAE,EAAE,CAAC,yCAAyC,EAAE,SAAS,CAAC,KAC/D,KAAK,aAET,KAAC,cAAc,IAAC,SAAS,EAAC,QAAQ,GAAG,EACrC,eAAM,SAAS,EAAC,SAAS,qBAAY,IAChC,CACR,CAAA;AACH,CAAC;AAED,OAAO,EACL,UAAU,EACV,cAAc,EACd,cAAc,EACd,cAAc,EACd,cAAc,EACd,mBAAmB,EACnB,kBAAkB,GACnB,CAAA"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { ButtonVariantProps, buttonVariants } from "@eggspot/ui/components/Button.variants";
|
|
2
|
+
import { type ButtonProps as AriaButtonProps } from "react-aria-components";
|
|
3
|
+
interface CommonButtonProps extends AriaButtonProps, React.RefAttributes<HTMLButtonElement>, ButtonVariantProps {
|
|
4
|
+
asChild?: boolean;
|
|
5
|
+
/** If true, the button will show a loading state */
|
|
6
|
+
isLoading?: boolean;
|
|
7
|
+
/** The delay of the tooltip */
|
|
8
|
+
tooltipDelay?: number;
|
|
9
|
+
/** If provided, the tooltip can be controlled externally */
|
|
10
|
+
tooltipIsOpen?: boolean;
|
|
11
|
+
/** Called when tooltip open state changes (hover/focus/escape/etc) */
|
|
12
|
+
onTooltipOpenChange?: (isOpen: boolean) => void;
|
|
13
|
+
/** The close delay of the tooltip */
|
|
14
|
+
tooltipCloseDelay?: number;
|
|
15
|
+
/** The test id of the button */
|
|
16
|
+
testId?: string;
|
|
17
|
+
/** If true, the button will show a badge */
|
|
18
|
+
withBadge?: boolean;
|
|
19
|
+
/** The badge number of the button */
|
|
20
|
+
badgeNumber?: number;
|
|
21
|
+
}
|
|
22
|
+
export interface IconButtonProps extends CommonButtonProps {
|
|
23
|
+
mode: "icon";
|
|
24
|
+
/** Tooltip text for the button. */
|
|
25
|
+
tooltip?: string | React.ReactNode;
|
|
26
|
+
/** The placement of the tooltip */
|
|
27
|
+
tooltipPlacement?: "top" | "bottom" | "left" | "right";
|
|
28
|
+
}
|
|
29
|
+
export interface DefaultButtonProps extends CommonButtonProps {
|
|
30
|
+
mode?: "default";
|
|
31
|
+
/** Optional tooltip for default buttons */
|
|
32
|
+
tooltip?: string | React.ReactNode;
|
|
33
|
+
/** The left icon of the button */
|
|
34
|
+
leftIcon?: React.ReactNode;
|
|
35
|
+
/** The right icon of the button */
|
|
36
|
+
rightIcon?: React.ReactNode;
|
|
37
|
+
/** If provided, the button will show a countdown */
|
|
38
|
+
countdown?: number;
|
|
39
|
+
/** The placement of the tooltip */
|
|
40
|
+
tooltipPlacement?: "top" | "bottom" | "left" | "right";
|
|
41
|
+
}
|
|
42
|
+
type ButtonProps = IconButtonProps | DefaultButtonProps;
|
|
43
|
+
declare function Button(props: ButtonProps): import("react/jsx-runtime").JSX.Element;
|
|
44
|
+
interface ButtonBadgeProps {
|
|
45
|
+
badgeNumber?: number;
|
|
46
|
+
className?: string;
|
|
47
|
+
maxVisibleNumber?: number;
|
|
48
|
+
intent?: "primary" | "secondary" | "danger";
|
|
49
|
+
}
|
|
50
|
+
declare function ButtonBadge({ badgeNumber, className, maxVisibleNumber, intent, }: ButtonBadgeProps): import("react/jsx-runtime").JSX.Element;
|
|
51
|
+
export { Button, ButtonBadge, buttonVariants };
|
|
52
|
+
export type { ButtonProps };
|
|
53
|
+
//# sourceMappingURL=Button.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.d.ts","sourceRoot":"","sources":["../../src/components/Button.tsx"],"names":[],"mappings":"AAGA,OAAO,EACL,kBAAkB,EAClB,cAAc,EACf,MAAM,wCAAwC,CAAA;AAQ/C,OAAO,EAIL,KAAK,WAAW,IAAI,eAAe,EACpC,MAAM,uBAAuB,CAAA;AAE9B,UAAU,iBACR,SAAQ,eAAe,EACrB,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,EACtC,kBAAkB;IAEpB,OAAO,CAAC,EAAE,OAAO,CAAA;IAEjB,oDAAoD;IACpD,SAAS,CAAC,EAAE,OAAO,CAAA;IAEnB,+BAA+B;IAC/B,YAAY,CAAC,EAAE,MAAM,CAAA;IAErB,4DAA4D;IAC5D,aAAa,CAAC,EAAE,OAAO,CAAA;IAEvB,sEAAsE;IACtE,mBAAmB,CAAC,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAAA;IAE/C,qCAAqC;IACrC,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAE1B,gCAAgC;IAChC,MAAM,CAAC,EAAE,MAAM,CAAA;IAEf,4CAA4C;IAC5C,SAAS,CAAC,EAAE,OAAO,CAAA;IAEnB,qCAAqC;IACrC,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB;AAED,MAAM,WAAW,eAAgB,SAAQ,iBAAiB;IACxD,IAAI,EAAE,MAAM,CAAA;IAEZ,mCAAmC;IACnC,OAAO,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC,SAAS,CAAA;IAElC,mCAAmC;IACnC,gBAAgB,CAAC,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,CAAA;CACvD;AACD,MAAM,WAAW,kBAAmB,SAAQ,iBAAiB;IAC3D,IAAI,CAAC,EAAE,SAAS,CAAA;IAEhB,2CAA2C;IAC3C,OAAO,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC,SAAS,CAAA;IAElC,kCAAkC;IAClC,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IAE1B,mCAAmC;IACnC,SAAS,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IAE3B,oDAAoD;IACpD,SAAS,CAAC,EAAE,MAAM,CAAA;IAElB,mCAAmC;IACnC,gBAAgB,CAAC,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,CAAA;CACvD;AAED,KAAK,WAAW,GAAG,eAAe,GAAG,kBAAkB,CAAA;AAEvD,iBAAS,MAAM,CAAC,KAAK,EAAE,WAAW,2CA8IjC;AAkBD,UAAU,gBAAgB;IACxB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,MAAM,CAAC,EAAE,SAAS,GAAG,WAAW,GAAG,QAAQ,CAAA;CAC5C;AAED,iBAAS,WAAW,CAAC,EACnB,WAAW,EACX,SAAS,EACT,gBAAoB,EACpB,MAAM,GACP,EAAE,gBAAgB,2CAalB;AAED,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,cAAc,EAAE,CAAA;AAC9C,YAAY,EAAE,WAAW,EAAE,CAAA"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { countdownMachine } from "@eggspot/ui/components/Button.machine";
|
|
4
|
+
import { buttonVariants, } from "@eggspot/ui/components/Button.variants";
|
|
5
|
+
import { Center, Float } from "@eggspot/ui/components/Layout";
|
|
6
|
+
import { Spinner } from "@eggspot/ui/components/Spinner";
|
|
7
|
+
import { Tooltip, TooltipTrigger } from "@eggspot/ui/components/Tooltip";
|
|
8
|
+
import { cn, formatCount } from "@eggspot/ui/lib/utils";
|
|
9
|
+
import { useMachine } from "@xstate/react";
|
|
10
|
+
import { cva } from "class-variance-authority";
|
|
11
|
+
import { Slot } from "radix-ui";
|
|
12
|
+
import { Button as AriaButton, Focusable, } from "react-aria-components";
|
|
13
|
+
function Button(props) {
|
|
14
|
+
const { mode, size, intent, variant = "solid", className, fullWidth, asChild = false, isLoading = false, children, isDisabled, tooltip, tooltipDelay = 0, tooltipIsOpen, onTooltipOpenChange, tooltipCloseDelay = 0, tooltipPlacement = "top", withBadge, badgeNumber, testId, onPress, ...restProps } = props;
|
|
15
|
+
const isDefault = mode === "default" || mode === undefined;
|
|
16
|
+
const defaultIntent = variant === "solid" || variant === "link" ? "primary" : "secondary";
|
|
17
|
+
const leftIcon = isDefault ? props.leftIcon : undefined;
|
|
18
|
+
const rightIcon = isDefault ? props.rightIcon : undefined;
|
|
19
|
+
// countdown and state machine setup
|
|
20
|
+
const hasCountdown = isDefault && props.countdown !== undefined;
|
|
21
|
+
const initialCount = isDefault ? props.countdown : undefined;
|
|
22
|
+
const [state, send] = useMachine(countdownMachine, {
|
|
23
|
+
input: {
|
|
24
|
+
initialCount: initialCount || 0,
|
|
25
|
+
},
|
|
26
|
+
});
|
|
27
|
+
const count = state.context.count;
|
|
28
|
+
const isCounting = hasCountdown && state.matches("Counting");
|
|
29
|
+
const countdownProps = hasCountdown
|
|
30
|
+
? {
|
|
31
|
+
onPress: (e) => {
|
|
32
|
+
send({ type: "START" });
|
|
33
|
+
onPress?.(e);
|
|
34
|
+
},
|
|
35
|
+
}
|
|
36
|
+
: {};
|
|
37
|
+
// rendering
|
|
38
|
+
const Comp = (asChild ? Slot.Root : AriaButton);
|
|
39
|
+
const isLoadingOrDisabled = isLoading || isDisabled || isCounting;
|
|
40
|
+
const ariaProps = asChild
|
|
41
|
+
? {}
|
|
42
|
+
: {
|
|
43
|
+
isPending: isLoading,
|
|
44
|
+
isDisabled: isLoadingOrDisabled,
|
|
45
|
+
};
|
|
46
|
+
const button = (_jsxs(Comp, { type: "button", "aria-label": mode === "icon" ? tooltip : undefined, "data-testid": testId, "data-has-right-element": !!rightIcon, "data-has-left-element": !!leftIcon, className: cn(buttonVariants({
|
|
47
|
+
mode,
|
|
48
|
+
size,
|
|
49
|
+
intent: intent || defaultIntent,
|
|
50
|
+
variant,
|
|
51
|
+
className,
|
|
52
|
+
fullWidth,
|
|
53
|
+
})), ...ariaProps, ...countdownProps, ...restProps, children: [isLoading && (_jsx(Center, { className: "spinner absolute inset-0 text-transparent", children: _jsx(Spinner, {}) })), withBadge && (_jsx(Float, { position: "top-right", children: _jsx(ButtonBadge, { badgeNumber: badgeNumber || 0, className: "border-gray-1 border" }) })), leftIcon, _jsx(Slot.Slottable, { children: children }), hasCountdown && isCounting && (_jsx(ButtonBadge, { intent: "secondary", badgeNumber: count, maxVisibleNumber: 99 })), rightIcon] }));
|
|
54
|
+
if (tooltip) {
|
|
55
|
+
const isControlled = tooltipIsOpen !== undefined;
|
|
56
|
+
return (_jsxs(TooltipTrigger, { delay: tooltipDelay, closeDelay: tooltipCloseDelay, ...(isControlled
|
|
57
|
+
? {
|
|
58
|
+
isOpen: tooltipIsOpen,
|
|
59
|
+
onOpenChange: onTooltipOpenChange ?? (() => { }),
|
|
60
|
+
}
|
|
61
|
+
: {}), children: [asChild ? _jsx(Focusable, { children: button }) : button, _jsx(Tooltip, { style: { zIndex: 100000000 }, placement: tooltipPlacement, children: tooltip })] }));
|
|
62
|
+
}
|
|
63
|
+
return button;
|
|
64
|
+
}
|
|
65
|
+
const badgeVariants = cva("bg-error-9 flex min-h-4 min-w-4 items-center justify-center rounded-full px-1 text-[10px] leading-[14px] text-white", {
|
|
66
|
+
variants: {
|
|
67
|
+
intent: {
|
|
68
|
+
primary: "bg-accent-9",
|
|
69
|
+
secondary: "bg-gray-9",
|
|
70
|
+
danger: "bg-error-9",
|
|
71
|
+
},
|
|
72
|
+
},
|
|
73
|
+
defaultVariants: {
|
|
74
|
+
intent: "danger",
|
|
75
|
+
},
|
|
76
|
+
});
|
|
77
|
+
function ButtonBadge({ badgeNumber, className, maxVisibleNumber = 9, intent, }) {
|
|
78
|
+
return (_jsx("div", { className: cn(badgeVariants({ intent }), badgeNumber && badgeNumber > maxVisibleNumber && "pr-[3px]", !badgeNumber && "min-h-3 min-w-3", className), children: badgeNumber ? formatCount(badgeNumber, maxVisibleNumber) : "" }));
|
|
79
|
+
}
|
|
80
|
+
export { Button, ButtonBadge, buttonVariants };
|
|
81
|
+
//# sourceMappingURL=Button.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.js","sourceRoot":"","sources":["../../src/components/Button.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export declare const countdownMachine: import("xstate").StateMachine<{
|
|
2
|
+
count: number;
|
|
3
|
+
initialCount: number;
|
|
4
|
+
}, {
|
|
5
|
+
type: "START";
|
|
6
|
+
}, Record<string, import("xstate").AnyActorRef>, import("xstate").ProvidedActor, import("xstate").ParameterizedObject, import("xstate").ParameterizedObject, string, import("xstate").StateValue, string, {
|
|
7
|
+
initialCount: number;
|
|
8
|
+
}, import("xstate").NonReducibleUnknown, import("xstate").EventObject, import("xstate").MetaObject, any>;
|
|
9
|
+
//# sourceMappingURL=Button.machine.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.machine.d.ts","sourceRoot":"","sources":["../../src/components/Button.machine.tsx"],"names":[],"mappings":"AAEA,eAAO,MAAM,gBAAgB;WAID,MAAM;kBAAgB,MAAM;;UAD9B,OAAO;;kBAEA,MAAM;wGA0CrC,CAAA"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { assign, createMachine } from "xstate";
|
|
2
|
+
export const countdownMachine = createMachine({
|
|
3
|
+
/** @xstate-layout N4IgpgJg5mDOIC5QGMD2BXAdgFwqg7pgHQCSmAltuQIYA2AxAMoAqAggErMDaADALqJQAB1SxK5VJkEgAHogC0ARgBMADiIB2ACwBWVVoCcqnhoDMGsxoA0IAJ6JzGojoNrl7jTwBsXjaoC+-jZoWLgExADCGDjkmFD0MrDY1NhgRNQAZqkATgAUijyFAJT0ITh4hERRobFQvAJIICJiVJLScggGOkQGGnoGpl08Blq+qjb2CMqKTjOqGq5epvpGy4HB0WGV1TFxCUkpaZk5+YU8JWVbkZu1XIoNwqLibY0dWspEJu+K8zoTiDpFERvr9AkEQJhUBA4NJLhUpI1ms8EaAOvJTCoiKZTEtVKoCtpvF5-gh0V5Pn4VDp1iA4eFSBQqHRpEjWijZAplF4tFicct8V8iSTHM5XMYeNiTPyaXTtjc4iynmz2ogeMLVOTqeDZcQAGKxciwAAWkEVLQk7I6arsAOmYP8QA */
|
|
4
|
+
types: {
|
|
5
|
+
events: {},
|
|
6
|
+
context: {},
|
|
7
|
+
input: {},
|
|
8
|
+
},
|
|
9
|
+
id: "countdown",
|
|
10
|
+
initial: "Initial",
|
|
11
|
+
context: ({ input }) => ({
|
|
12
|
+
count: input.initialCount,
|
|
13
|
+
initialCount: input.initialCount,
|
|
14
|
+
}),
|
|
15
|
+
states: {
|
|
16
|
+
Initial: {
|
|
17
|
+
on: {
|
|
18
|
+
START: {
|
|
19
|
+
target: "Counting",
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
Counting: {
|
|
24
|
+
after: {
|
|
25
|
+
1000: [
|
|
26
|
+
{
|
|
27
|
+
guard: ({ context }) => context.count === 1,
|
|
28
|
+
target: "Finished",
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
actions: assign(({ context }) => ({
|
|
32
|
+
count: context.count - 1,
|
|
33
|
+
})),
|
|
34
|
+
target: "Counting",
|
|
35
|
+
reenter: true,
|
|
36
|
+
},
|
|
37
|
+
],
|
|
38
|
+
},
|
|
39
|
+
},
|
|
40
|
+
Finished: {
|
|
41
|
+
always: {
|
|
42
|
+
target: "Initial",
|
|
43
|
+
actions: assign(({ context }) => ({
|
|
44
|
+
count: context.initialCount,
|
|
45
|
+
})),
|
|
46
|
+
},
|
|
47
|
+
},
|
|
48
|
+
},
|
|
49
|
+
});
|
|
50
|
+
//# sourceMappingURL=Button.machine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.machine.js","sourceRoot":"","sources":["../../src/components/Button.machine.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAA;AAE9C,MAAM,CAAC,MAAM,gBAAgB,GAAG,aAAa,CAAC;IAC5C,yfAAyf;IACzf,KAAK,EAAE;QACL,MAAM,EAAE,EAAuB;QAC/B,OAAO,EAAE,EAA6C;QACtD,KAAK,EAAE,EAA8B;KACtC;IACD,EAAE,EAAE,WAAW;IACf,OAAO,EAAE,SAAS;IAClB,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;QACvB,KAAK,EAAE,KAAK,CAAC,YAAY;QACzB,YAAY,EAAE,KAAK,CAAC,YAAY;KACjC,CAAC;IACF,MAAM,EAAE;QACN,OAAO,EAAE;YACP,EAAE,EAAE;gBACF,KAAK,EAAE;oBACL,MAAM,EAAE,UAAU;iBACnB;aACF;SACF;QACD,QAAQ,EAAE;YACR,KAAK,EAAE;gBACL,IAAI,EAAE;oBACJ;wBACE,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,KAAK,CAAC;wBAC3C,MAAM,EAAE,UAAU;qBACnB;oBACD;wBACE,OAAO,EAAE,MAAM,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC;4BAChC,KAAK,EAAE,OAAO,CAAC,KAAK,GAAG,CAAC;yBACzB,CAAC,CAAC;wBACH,MAAM,EAAE,UAAU;wBAClB,OAAO,EAAE,IAAI;qBACd;iBACF;aACF;SACF;QACD,QAAQ,EAAE;YACR,MAAM,EAAE;gBACN,MAAM,EAAE,SAAS;gBACjB,OAAO,EAAE,MAAM,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC;oBAChC,KAAK,EAAE,OAAO,CAAC,YAAY;iBAC5B,CAAC,CAAC;aACJ;SACF;KACF;CACF,CAAC,CAAA"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type VariantProps } from "class-variance-authority";
|
|
2
|
+
export declare const buttonVariants: (props?: ({
|
|
3
|
+
mode?: "default" | "icon" | null | undefined;
|
|
4
|
+
size?: "sm" | "md" | "lg" | "xs" | null | undefined;
|
|
5
|
+
intent?: "primary" | "secondary" | "danger" | null | undefined;
|
|
6
|
+
variant?: "link" | "solid" | "outline" | "ghost" | "minimal" | "unstyled" | null | undefined;
|
|
7
|
+
fullWidth?: boolean | null | undefined;
|
|
8
|
+
} & import("class-variance-authority/dist/types").ClassProp) | undefined) => string;
|
|
9
|
+
export type ButtonVariantProps = VariantProps<typeof buttonVariants>;
|
|
10
|
+
//# sourceMappingURL=Button.variants.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.variants.d.ts","sourceRoot":"","sources":["../../src/components/Button.variants.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAEjE,eAAO,MAAM,cAAc;;;;;;mFAyN1B,CAAA;AAED,MAAM,MAAM,kBAAkB,GAAG,YAAY,CAAC,OAAO,cAAc,CAAC,CAAA"}
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
import { cva } from "class-variance-authority";
|
|
2
|
+
export const buttonVariants = cva([
|
|
3
|
+
"text-gray-12 relative inline-flex cursor-pointer items-center justify-center gap-1.5 rounded-md text-sm font-medium whitespace-nowrap no-underline transition-[transform,background-color] duration-100 select-none",
|
|
4
|
+
/* SVGs */
|
|
5
|
+
"[&_svg]:pointer-events-none [&_svg]:size-[14px] [&_svg]:shrink-0 [&_svg]:stroke-2",
|
|
6
|
+
/* Pressed */
|
|
7
|
+
"data-pressed:transform-[scale(0.98)]",
|
|
8
|
+
/* Disabled */
|
|
9
|
+
"disabled:cursor-not-allowed disabled:opacity-55",
|
|
10
|
+
/* Loading */
|
|
11
|
+
"data-pending:text-transparent data-pending:[&>.spinner]:text-white",
|
|
12
|
+
/* Focus Visible */
|
|
13
|
+
"focus-visible:ring-2 focus-visible:outline-none",
|
|
14
|
+
/* Resets */
|
|
15
|
+
"focus-visible:outline-none",
|
|
16
|
+
], {
|
|
17
|
+
variants: {
|
|
18
|
+
mode: {
|
|
19
|
+
default: "",
|
|
20
|
+
icon: "",
|
|
21
|
+
},
|
|
22
|
+
size: {
|
|
23
|
+
xs: [
|
|
24
|
+
"h-5 gap-1 px-1.5 text-[12px]",
|
|
25
|
+
/* Optically align elements */
|
|
26
|
+
"data-[has-left-element=true]:pl-1 data-[has-right-element=true]:pr-1",
|
|
27
|
+
],
|
|
28
|
+
sm: [
|
|
29
|
+
"h-7 px-2 text-[13px]",
|
|
30
|
+
/* Optically align elements */
|
|
31
|
+
"data-[has-left-element=true]:pl-1.5 data-[has-right-element=true]:pr-1.5",
|
|
32
|
+
],
|
|
33
|
+
md: [
|
|
34
|
+
"h-8 px-3 py-2",
|
|
35
|
+
/* Optically align elements */
|
|
36
|
+
"data-[has-left-element=true]:pl-2 data-[has-right-element=true]:pr-2",
|
|
37
|
+
],
|
|
38
|
+
lg: [
|
|
39
|
+
"h-10 gap-2 px-4",
|
|
40
|
+
/* Optically align elements */
|
|
41
|
+
"data-[has-left-element=true]:pl-[10px] data-[has-right-element=true]:pr-[10px]",
|
|
42
|
+
],
|
|
43
|
+
},
|
|
44
|
+
intent: {
|
|
45
|
+
primary: "ring-accent-7",
|
|
46
|
+
secondary: "ring-gray-7",
|
|
47
|
+
danger: "ring-error-7",
|
|
48
|
+
},
|
|
49
|
+
variant: {
|
|
50
|
+
solid: "",
|
|
51
|
+
outline: "",
|
|
52
|
+
ghost: "",
|
|
53
|
+
minimal: "",
|
|
54
|
+
link: "p-0",
|
|
55
|
+
unstyled: "cursor-default p-0",
|
|
56
|
+
},
|
|
57
|
+
fullWidth: {
|
|
58
|
+
true: "w-full",
|
|
59
|
+
},
|
|
60
|
+
},
|
|
61
|
+
compoundVariants: [
|
|
62
|
+
/* Primary */
|
|
63
|
+
{
|
|
64
|
+
variant: "solid",
|
|
65
|
+
intent: "primary",
|
|
66
|
+
className: [
|
|
67
|
+
"bg-accent-9 text-accent-contrast hover:not-disabled:bg-accent-10",
|
|
68
|
+
"border border-black/5 dark:border-white/10",
|
|
69
|
+
],
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
variant: "outline",
|
|
73
|
+
intent: "primary",
|
|
74
|
+
className: [
|
|
75
|
+
"bg-accent-2 border-accent-7 text-accent-11 hover:not-disabled:bg-accent-3 border",
|
|
76
|
+
"data-pending:[&>.spinner]:text-accent-11",
|
|
77
|
+
],
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
variant: "ghost",
|
|
81
|
+
intent: "primary",
|
|
82
|
+
className: [
|
|
83
|
+
"text-accent-11 hover:not-disabled:bg-accent-3",
|
|
84
|
+
"data-pending:[&>.spinner]:text-accent-11 data-pending:bg-accent-3",
|
|
85
|
+
],
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
variant: "minimal",
|
|
89
|
+
intent: "primary",
|
|
90
|
+
className: [
|
|
91
|
+
"text-accent-11 bg-accent-3 hover:not-disabled:bg-accent-4",
|
|
92
|
+
"data-pending:[&>.spinner]:text-accent-11",
|
|
93
|
+
],
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
variant: "link",
|
|
97
|
+
intent: "primary",
|
|
98
|
+
className: [
|
|
99
|
+
"text-accent-11 h-auto px-0 hover:not-disabled:underline",
|
|
100
|
+
"data-pending:[&>.spinner]:text-accent-11 data-pending:bg-accent-3",
|
|
101
|
+
],
|
|
102
|
+
},
|
|
103
|
+
/* Secondary */
|
|
104
|
+
{
|
|
105
|
+
variant: "solid",
|
|
106
|
+
intent: "secondary",
|
|
107
|
+
className: [
|
|
108
|
+
"bg-gray-3 border-gray-3 hover:not-disabled:bg-gray-4 hover:not-disabled:border-gray-4 border",
|
|
109
|
+
"data-pending:[&>.spinner]:text-gray-11",
|
|
110
|
+
],
|
|
111
|
+
},
|
|
112
|
+
{
|
|
113
|
+
variant: "outline",
|
|
114
|
+
intent: "secondary",
|
|
115
|
+
className: [
|
|
116
|
+
"bg-gray-2 border-gray-7 hover:not-disabled:bg-gray-3 border",
|
|
117
|
+
"data-pending:[&>.spinner]:text-gray-11",
|
|
118
|
+
],
|
|
119
|
+
},
|
|
120
|
+
{
|
|
121
|
+
variant: "ghost",
|
|
122
|
+
intent: "secondary",
|
|
123
|
+
className: [
|
|
124
|
+
"hover:not-disabled:bg-gray-4",
|
|
125
|
+
"data-pending:[&>.spinner]:text-gray-11 data-pending:bg-gray-3",
|
|
126
|
+
],
|
|
127
|
+
},
|
|
128
|
+
{
|
|
129
|
+
variant: "minimal",
|
|
130
|
+
intent: "secondary",
|
|
131
|
+
className: [
|
|
132
|
+
"bg-gray-3 hover:not-disabled:bg-gray-4",
|
|
133
|
+
"data-pending:[&>.spinner]:text-gray-11",
|
|
134
|
+
],
|
|
135
|
+
},
|
|
136
|
+
{
|
|
137
|
+
variant: "link",
|
|
138
|
+
intent: "secondary",
|
|
139
|
+
className: [
|
|
140
|
+
"text-gray-11 h-auto px-0 hover:not-disabled:underline",
|
|
141
|
+
"data-pending:[&>.spinner]:text-gray-11 data-pending:bg-gray-3",
|
|
142
|
+
],
|
|
143
|
+
},
|
|
144
|
+
/* Danger */
|
|
145
|
+
{
|
|
146
|
+
variant: "solid",
|
|
147
|
+
intent: "danger",
|
|
148
|
+
className: [
|
|
149
|
+
"bg-error-9 hover:not-disabled:bg-error-10 text-white",
|
|
150
|
+
"border border-black/5 dark:border-white/10",
|
|
151
|
+
],
|
|
152
|
+
},
|
|
153
|
+
{
|
|
154
|
+
variant: "outline",
|
|
155
|
+
intent: "danger",
|
|
156
|
+
className: [
|
|
157
|
+
"bg-error-2 text-error-11 border-error-7 hover:not-disabled:bg-error-3 border",
|
|
158
|
+
"data-pending:[&>.spinner]:text-error-11",
|
|
159
|
+
],
|
|
160
|
+
},
|
|
161
|
+
{
|
|
162
|
+
variant: "ghost",
|
|
163
|
+
intent: "danger",
|
|
164
|
+
className: [
|
|
165
|
+
"text-error-11 hover:not-disabled:bg-error-3",
|
|
166
|
+
"data-pending:[&>.spinner]:text-error-11 data-pending:bg-error-3",
|
|
167
|
+
],
|
|
168
|
+
},
|
|
169
|
+
{
|
|
170
|
+
variant: "minimal",
|
|
171
|
+
intent: "danger",
|
|
172
|
+
className: [
|
|
173
|
+
"text-error-11 bg-error-3 hover:not-disabled:bg-error-4",
|
|
174
|
+
"data-pending:[&>.spinner]:text-error-11",
|
|
175
|
+
],
|
|
176
|
+
},
|
|
177
|
+
{
|
|
178
|
+
variant: "link",
|
|
179
|
+
intent: "danger",
|
|
180
|
+
className: [
|
|
181
|
+
"text-error-11 h-auto px-0 hover:not-disabled:underline",
|
|
182
|
+
"data-pending:[&>.spinner]:text-error-11 data-pending:bg-error-3",
|
|
183
|
+
],
|
|
184
|
+
},
|
|
185
|
+
/* Mode */
|
|
186
|
+
{
|
|
187
|
+
mode: "icon",
|
|
188
|
+
size: "xs",
|
|
189
|
+
className: ["size-5 [&_svg]:size-3"],
|
|
190
|
+
},
|
|
191
|
+
{
|
|
192
|
+
mode: "icon",
|
|
193
|
+
size: "sm",
|
|
194
|
+
className: ["size-7 [&_svg]:size-4"],
|
|
195
|
+
},
|
|
196
|
+
{
|
|
197
|
+
mode: "icon",
|
|
198
|
+
size: "md",
|
|
199
|
+
className: ["size-8 [&_svg]:size-4"],
|
|
200
|
+
},
|
|
201
|
+
{
|
|
202
|
+
mode: "icon",
|
|
203
|
+
size: "lg",
|
|
204
|
+
className: ["size-10 [&_svg]:size-5"],
|
|
205
|
+
},
|
|
206
|
+
],
|
|
207
|
+
defaultVariants: {
|
|
208
|
+
variant: "solid",
|
|
209
|
+
intent: "primary",
|
|
210
|
+
size: "md",
|
|
211
|
+
mode: "default",
|
|
212
|
+
},
|
|
213
|
+
});
|
|
214
|
+
//# sourceMappingURL=Button.variants.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.variants.js","sourceRoot":"","sources":["../../src/components/Button.variants.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Separator } from "@eggspot/ui/components/Separator";
|
|
2
|
+
import { type VariantProps } from "class-variance-authority";
|
|
3
|
+
declare const buttonGroupVariants: (props?: ({
|
|
4
|
+
orientation?: "horizontal" | "vertical" | null | undefined;
|
|
5
|
+
} & import("class-variance-authority/dist/types").ClassProp) | undefined) => string;
|
|
6
|
+
declare function ButtonGroup({ className, orientation, ...props }: React.ComponentProps<"div"> & VariantProps<typeof buttonGroupVariants>): import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
declare function ButtonGroupSeparator({ className, orientation, ...props }: React.ComponentProps<typeof Separator>): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
export { ButtonGroup, ButtonGroupSeparator, buttonGroupVariants };
|
|
9
|
+
//# sourceMappingURL=ButtonGroup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ButtonGroup.d.ts","sourceRoot":"","sources":["../../src/components/ButtonGroup.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAA;AAE5D,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAEjE,QAAA,MAAM,mBAAmB;;mFAexB,CAAA;AAED,iBAAS,WAAW,CAAC,EACnB,SAAS,EACT,WAAW,EACX,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG,YAAY,CAAC,OAAO,mBAAmB,CAAC,2CAUxE;AAED,iBAAS,oBAAoB,CAAC,EAC5B,SAAS,EACT,WAAwB,EACxB,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,SAAS,CAAC,2CAYxC;AAED,OAAO,EAAE,WAAW,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,CAAA"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Separator } from "@eggspot/ui/components/Separator";
|
|
3
|
+
import { cn } from "@eggspot/ui/lib/utils";
|
|
4
|
+
import { cva } from "class-variance-authority";
|
|
5
|
+
const buttonGroupVariants = cva("flex w-fit items-stretch has-[>[data-slot=button-group]]:gap-2 [&>*]:focus-visible:relative [&>*]:focus-visible:z-10 [&>input]:flex-1", {
|
|
6
|
+
variants: {
|
|
7
|
+
orientation: {
|
|
8
|
+
horizontal: "[&>*:not(:first-child)]:rounded-l-none [&>*:not(:first-child)]:border-l-0 [&>*:not(:last-child)]:rounded-r-none",
|
|
9
|
+
vertical: "flex-col [&>*:not(:first-child)]:rounded-t-none [&>*:not(:first-child)]:border-t-0 [&>*:not(:last-child)]:rounded-b-none",
|
|
10
|
+
},
|
|
11
|
+
},
|
|
12
|
+
defaultVariants: {
|
|
13
|
+
orientation: "horizontal",
|
|
14
|
+
},
|
|
15
|
+
});
|
|
16
|
+
function ButtonGroup({ className, orientation, ...props }) {
|
|
17
|
+
return (_jsx("div", { role: "group", "data-slot": "button-group", "data-orientation": orientation, className: cn(buttonGroupVariants({ orientation }), className), ...props }));
|
|
18
|
+
}
|
|
19
|
+
function ButtonGroupSeparator({ className, orientation = "vertical", ...props }) {
|
|
20
|
+
return (_jsx(Separator, { "data-slot": "button-group-separator", orientation: orientation, className: cn("bg-input relative m-0! self-stretch data-[orientation=vertical]:h-auto", className), ...props }));
|
|
21
|
+
}
|
|
22
|
+
export { ButtonGroup, ButtonGroupSeparator, buttonGroupVariants };
|
|
23
|
+
//# sourceMappingURL=ButtonGroup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ButtonGroup.js","sourceRoot":"","sources":["../../src/components/ButtonGroup.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAA;AAC5D,OAAO,EAAE,EAAE,EAAE,MAAM,uBAAuB,CAAA;AAC1C,OAAO,EAAE,GAAG,EAAqB,MAAM,0BAA0B,CAAA;AAEjE,MAAM,mBAAmB,GAAG,GAAG,CAC7B,uIAAuI,EACvI;IACE,QAAQ,EAAE;QACR,WAAW,EAAE;YACX,UAAU,EACR,iHAAiH;YACnH,QAAQ,EACN,0HAA0H;SAC7H;KACF;IACD,eAAe,EAAE;QACf,WAAW,EAAE,YAAY;KAC1B;CACF,CACF,CAAA;AAED,SAAS,WAAW,CAAC,EACnB,SAAS,EACT,WAAW,EACX,GAAG,KAAK,EAC+D;IACvE,OAAO,CACL,cACE,IAAI,EAAC,OAAO,eACF,cAAc,sBACN,WAAW,EAC7B,SAAS,EAAE,EAAE,CAAC,mBAAmB,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,SAAS,CAAC,KAC1D,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,SAAS,oBAAoB,CAAC,EAC5B,SAAS,EACT,WAAW,GAAG,UAAU,EACxB,GAAG,KAAK,EAC+B;IACvC,OAAO,CACL,KAAC,SAAS,iBACE,wBAAwB,EAClC,WAAW,EAAE,WAAW,EACxB,SAAS,EAAE,EAAE,CACX,wEAAwE,EACxE,SAAS,CACV,KACG,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,OAAO,EAAE,WAAW,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,CAAA"}
|