@uppsala-designsystem/ui 1.5.0
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/LICENSE +7 -0
- package/README.md +9 -0
- package/dist/cjs/components/Alert/Alert.js +18 -0
- package/dist/cjs/components/Avatar/Avatar.js +31 -0
- package/dist/cjs/components/Badge/Badge.js +23 -0
- package/dist/cjs/components/Badge/BadgePosition.js +21 -0
- package/dist/cjs/components/Badge/index.js +17 -0
- package/dist/cjs/components/Breadcrumbs/Breadcrumbs.js +28 -0
- package/dist/cjs/components/Breadcrumbs/BreadcrumbsItem.js +11 -0
- package/dist/cjs/components/Breadcrumbs/BreadcrumbsLink.js +12 -0
- package/dist/cjs/components/Breadcrumbs/BreadcrumbsList.js +21 -0
- package/dist/cjs/components/Breadcrumbs/index.js +39 -0
- package/dist/cjs/components/Button/Button.js +25 -0
- package/dist/cjs/components/Card/Card.js +43 -0
- package/dist/cjs/components/Card/CardBlock.js +14 -0
- package/dist/cjs/components/Card/index.js +23 -0
- package/dist/cjs/components/Checkbox/Checkbox.js +21 -0
- package/dist/cjs/components/Chip/Chips.js +52 -0
- package/dist/cjs/components/Chip/index.js +21 -0
- package/dist/cjs/components/Details/Details.js +43 -0
- package/dist/cjs/components/Details/DetailsContent.js +17 -0
- package/dist/cjs/components/Details/DetailsSummary.js +18 -0
- package/dist/cjs/components/Details/index.js +26 -0
- package/dist/cjs/components/Dialog/Dialog.js +82 -0
- package/dist/cjs/components/Dialog/DialogBlock.js +30 -0
- package/dist/cjs/components/Dialog/DialogTrigger.js +33 -0
- package/dist/cjs/components/Dialog/DialogTriggerContext.js +28 -0
- package/dist/cjs/components/Dialog/index.js +34 -0
- package/dist/cjs/components/Divider/Divider.js +20 -0
- package/dist/cjs/components/Dropdown/Dropdown.js +40 -0
- package/dist/cjs/components/Dropdown/DropdownButton.js +12 -0
- package/dist/cjs/components/Dropdown/DropdownHeading.js +12 -0
- package/dist/cjs/components/Dropdown/DropdownItem.js +11 -0
- package/dist/cjs/components/Dropdown/DropdownList.js +11 -0
- package/dist/cjs/components/Dropdown/DropdownTrigger.js +13 -0
- package/dist/cjs/components/Dropdown/DropdownTriggerContext.js +29 -0
- package/dist/cjs/components/Dropdown/index.js +49 -0
- package/dist/cjs/components/ErrorSummary/ErrorSummary.js +37 -0
- package/dist/cjs/components/ErrorSummary/ErrorSummaryHeading.js +18 -0
- package/dist/cjs/components/ErrorSummary/ErrorSummaryItem.js +19 -0
- package/dist/cjs/components/ErrorSummary/ErrorSummaryLink.js +15 -0
- package/dist/cjs/components/ErrorSummary/ErrorSummaryList.js +12 -0
- package/dist/cjs/components/ErrorSummary/index.js +41 -0
- package/dist/cjs/components/Field/Field.js +28 -0
- package/dist/cjs/components/Field/FieldAffix.js +37 -0
- package/dist/cjs/components/Field/FieldCounter.js +40 -0
- package/dist/cjs/components/Field/FieldDescription.js +11 -0
- package/dist/cjs/components/Field/fieldObserver.js +102 -0
- package/dist/cjs/components/Field/index.js +35 -0
- package/dist/cjs/components/Fieldset/Fieldset.js +27 -0
- package/dist/cjs/components/Fieldset/FieldsetDescription.js +20 -0
- package/dist/cjs/components/Fieldset/FieldsetLegend.js +18 -0
- package/dist/cjs/components/Fieldset/index.js +32 -0
- package/dist/cjs/components/Heading/Heading.js +20 -0
- package/dist/cjs/components/InfoCard/InfoCard.js +24 -0
- package/dist/cjs/components/Input/Input.js +22 -0
- package/dist/cjs/components/Label/Label.js +20 -0
- package/dist/cjs/components/Link/Link.js +21 -0
- package/dist/cjs/components/List/ListItem.js +13 -0
- package/dist/cjs/components/List/Lists.js +41 -0
- package/dist/cjs/components/List/index.js +19 -0
- package/dist/cjs/components/Pagination/Pagination.js +32 -0
- package/dist/cjs/components/Pagination/PaginationButton.js +20 -0
- package/dist/cjs/components/Pagination/PaginationItem.js +23 -0
- package/dist/cjs/components/Pagination/PaginationList.js +25 -0
- package/dist/cjs/components/Pagination/index.js +39 -0
- package/dist/cjs/components/Paragraph/Paragraph.js +21 -0
- package/dist/cjs/components/Popover/Popover.js +135 -0
- package/dist/cjs/components/Popover/PopoverTrigger.js +45 -0
- package/dist/cjs/components/Popover/PopoverTriggerContext.js +27 -0
- package/dist/cjs/components/Popover/index.js +28 -0
- package/dist/cjs/components/Radio/Radio.js +21 -0
- package/dist/cjs/components/Search/Search.js +28 -0
- package/dist/cjs/components/Search/SearchButton.js +21 -0
- package/dist/cjs/components/Search/SearchClear.js +47 -0
- package/dist/cjs/components/Search/SearchInput.js +22 -0
- package/dist/cjs/components/Search/index.js +37 -0
- package/dist/cjs/components/Select/Select.js +31 -0
- package/dist/cjs/components/Select/SelectOptgroup.js +24 -0
- package/dist/cjs/components/Select/SelectOption.js +22 -0
- package/dist/cjs/components/Select/index.js +26 -0
- package/dist/cjs/components/Skeleton/Skeleton.js +27 -0
- package/dist/cjs/components/SkipLink/SkipLink.js +19 -0
- package/dist/cjs/components/Spinner/Spinner.js +23 -0
- package/dist/cjs/components/Suggestion/Suggestion.js +101 -0
- package/dist/cjs/components/Suggestion/SuggestionChips.js +13 -0
- package/dist/cjs/components/Suggestion/SuggestionClear.js +24 -0
- package/dist/cjs/components/Suggestion/SuggestionEmpty.js +23 -0
- package/dist/cjs/components/Suggestion/SuggestionInput.js +34 -0
- package/dist/cjs/components/Suggestion/SuggestionList.js +51 -0
- package/dist/cjs/components/Suggestion/SuggestionOption.js +11 -0
- package/dist/cjs/components/Suggestion/index.js +71 -0
- package/dist/cjs/components/Switch/Switch.js +20 -0
- package/dist/cjs/components/Table/Table.js +37 -0
- package/dist/cjs/components/Table/TableBody.js +22 -0
- package/dist/cjs/components/Table/TableCell.js +17 -0
- package/dist/cjs/components/Table/TableFoot.js +22 -0
- package/dist/cjs/components/Table/TableHead.js +22 -0
- package/dist/cjs/components/Table/TableHeaderCell.js +17 -0
- package/dist/cjs/components/Table/TableRow.js +20 -0
- package/dist/cjs/components/Table/index.js +59 -0
- package/dist/cjs/components/Tabs/Tabs.js +43 -0
- package/dist/cjs/components/Tabs/TabsList.js +23 -0
- package/dist/cjs/components/Tabs/TabsPanel.js +31 -0
- package/dist/cjs/components/Tabs/TabsTab.js +21 -0
- package/dist/cjs/components/Tabs/index.js +36 -0
- package/dist/cjs/components/Tag/Tag.js +18 -0
- package/dist/cjs/components/Textarea/Textarea.js +18 -0
- package/dist/cjs/components/Textfield/Textfield.js +27 -0
- package/dist/cjs/components/Timeline/Timeline.js +25 -0
- package/dist/cjs/components/Timeline/TimelineItem.js +23 -0
- package/dist/cjs/components/Timeline/index.js +27 -0
- package/dist/cjs/components/ToggleGroup/ToggleGroup.js +129 -0
- package/dist/cjs/components/ToggleGroup/ToggleGroupItem.js +20 -0
- package/dist/cjs/components/ToggleGroup/index.js +23 -0
- package/dist/cjs/components/ToggleGroup/useToggleGroupitem.js +32 -0
- package/dist/cjs/components/Tooltip/Tooltip.js +122 -0
- package/dist/cjs/components/ValidationMessage/ValidationMessage.js +20 -0
- package/dist/cjs/index.js +242 -0
- package/dist/cjs/layouts/Container/Container.js +19 -0
- package/dist/cjs/layouts/Grid/GridCol.js +12 -0
- package/dist/cjs/layouts/Grid/GridRow.js +12 -0
- package/dist/cjs/utilities/RovingFocus/RovingFocusItem.js +72 -0
- package/dist/cjs/utilities/RovingFocus/RovingFocusRoot.js +72 -0
- package/dist/cjs/utilities/RovingFocus/useRovingFocus.js +43 -0
- package/dist/cjs/utilities/hooks/useCheckboxGroup/useCheckboxGroup.js +121 -0
- package/dist/cjs/utilities/hooks/useDebounceCallback/useDebounceCallback.js +27 -0
- package/dist/cjs/utilities/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.js +9 -0
- package/dist/cjs/utilities/hooks/useMediaQuery/useMediaQuery.js +49 -0
- package/dist/cjs/utilities/hooks/useMergeRefs/useMergeRefs.js +57 -0
- package/dist/cjs/utilities/hooks/usePagination/usePagination.js +97 -0
- package/dist/cjs/utilities/hooks/useRadioGroup/useRadioGroup.js +99 -0
- package/dist/cjs/utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.js +48 -0
- package/dist/cjs/utilities/omit/omit.js +28 -0
- package/dist/esm/components/Alert/Alert.js +16 -0
- package/dist/esm/components/Avatar/Avatar.js +29 -0
- package/dist/esm/components/Badge/Badge.js +21 -0
- package/dist/esm/components/Badge/BadgePosition.js +19 -0
- package/dist/esm/components/Badge/index.js +14 -0
- package/dist/esm/components/Breadcrumbs/Breadcrumbs.js +26 -0
- package/dist/esm/components/Breadcrumbs/BreadcrumbsItem.js +9 -0
- package/dist/esm/components/Breadcrumbs/BreadcrumbsLink.js +10 -0
- package/dist/esm/components/Breadcrumbs/BreadcrumbsList.js +19 -0
- package/dist/esm/components/Breadcrumbs/index.js +34 -0
- package/dist/esm/components/Button/Button.js +23 -0
- package/dist/esm/components/Card/Card.js +41 -0
- package/dist/esm/components/Card/CardBlock.js +12 -0
- package/dist/esm/components/Card/index.js +20 -0
- package/dist/esm/components/Checkbox/Checkbox.js +19 -0
- package/dist/esm/components/Chip/Chips.js +47 -0
- package/dist/esm/components/Chip/index.js +15 -0
- package/dist/esm/components/Details/Details.js +41 -0
- package/dist/esm/components/Details/DetailsContent.js +15 -0
- package/dist/esm/components/Details/DetailsSummary.js +16 -0
- package/dist/esm/components/Details/index.js +22 -0
- package/dist/esm/components/Dialog/Dialog.js +80 -0
- package/dist/esm/components/Dialog/DialogBlock.js +28 -0
- package/dist/esm/components/Dialog/DialogTrigger.js +31 -0
- package/dist/esm/components/Dialog/DialogTriggerContext.js +25 -0
- package/dist/esm/components/Dialog/index.js +29 -0
- package/dist/esm/components/Divider/Divider.js +18 -0
- package/dist/esm/components/Dropdown/Dropdown.js +38 -0
- package/dist/esm/components/Dropdown/DropdownButton.js +10 -0
- package/dist/esm/components/Dropdown/DropdownHeading.js +10 -0
- package/dist/esm/components/Dropdown/DropdownItem.js +9 -0
- package/dist/esm/components/Dropdown/DropdownList.js +9 -0
- package/dist/esm/components/Dropdown/DropdownTrigger.js +11 -0
- package/dist/esm/components/Dropdown/DropdownTriggerContext.js +27 -0
- package/dist/esm/components/Dropdown/index.js +41 -0
- package/dist/esm/components/ErrorSummary/ErrorSummary.js +34 -0
- package/dist/esm/components/ErrorSummary/ErrorSummaryHeading.js +16 -0
- package/dist/esm/components/ErrorSummary/ErrorSummaryItem.js +17 -0
- package/dist/esm/components/ErrorSummary/ErrorSummaryLink.js +13 -0
- package/dist/esm/components/ErrorSummary/ErrorSummaryList.js +10 -0
- package/dist/esm/components/ErrorSummary/index.js +35 -0
- package/dist/esm/components/Field/Field.js +26 -0
- package/dist/esm/components/Field/FieldAffix.js +34 -0
- package/dist/esm/components/Field/FieldCounter.js +38 -0
- package/dist/esm/components/Field/FieldDescription.js +9 -0
- package/dist/esm/components/Field/fieldObserver.js +97 -0
- package/dist/esm/components/Field/index.js +29 -0
- package/dist/esm/components/Fieldset/Fieldset.js +25 -0
- package/dist/esm/components/Fieldset/FieldsetDescription.js +18 -0
- package/dist/esm/components/Fieldset/FieldsetLegend.js +16 -0
- package/dist/esm/components/Fieldset/index.js +28 -0
- package/dist/esm/components/Heading/Heading.js +18 -0
- package/dist/esm/components/InfoCard/InfoCard.js +22 -0
- package/dist/esm/components/Input/Input.js +20 -0
- package/dist/esm/components/Label/Label.js +18 -0
- package/dist/esm/components/Link/Link.js +19 -0
- package/dist/esm/components/List/ListItem.js +11 -0
- package/dist/esm/components/List/Lists.js +38 -0
- package/dist/esm/components/List/index.js +14 -0
- package/dist/esm/components/Pagination/Pagination.js +30 -0
- package/dist/esm/components/Pagination/PaginationButton.js +18 -0
- package/dist/esm/components/Pagination/PaginationItem.js +21 -0
- package/dist/esm/components/Pagination/PaginationList.js +23 -0
- package/dist/esm/components/Pagination/index.js +34 -0
- package/dist/esm/components/Paragraph/Paragraph.js +19 -0
- package/dist/esm/components/Popover/Popover.js +133 -0
- package/dist/esm/components/Popover/PopoverTrigger.js +43 -0
- package/dist/esm/components/Popover/PopoverTriggerContext.js +24 -0
- package/dist/esm/components/Popover/index.js +24 -0
- package/dist/esm/components/Radio/Radio.js +19 -0
- package/dist/esm/components/Search/Search.js +26 -0
- package/dist/esm/components/Search/SearchButton.js +19 -0
- package/dist/esm/components/Search/SearchClear.js +44 -0
- package/dist/esm/components/Search/SearchInput.js +20 -0
- package/dist/esm/components/Search/index.js +32 -0
- package/dist/esm/components/Select/Select.js +29 -0
- package/dist/esm/components/Select/SelectOptgroup.js +22 -0
- package/dist/esm/components/Select/SelectOption.js +20 -0
- package/dist/esm/components/Select/index.js +22 -0
- package/dist/esm/components/Skeleton/Skeleton.js +25 -0
- package/dist/esm/components/SkipLink/SkipLink.js +17 -0
- package/dist/esm/components/Spinner/Spinner.js +21 -0
- package/dist/esm/components/Suggestion/Suggestion.js +98 -0
- package/dist/esm/components/Suggestion/SuggestionChips.js +11 -0
- package/dist/esm/components/Suggestion/SuggestionClear.js +22 -0
- package/dist/esm/components/Suggestion/SuggestionEmpty.js +21 -0
- package/dist/esm/components/Suggestion/SuggestionInput.js +32 -0
- package/dist/esm/components/Suggestion/SuggestionList.js +49 -0
- package/dist/esm/components/Suggestion/SuggestionOption.js +9 -0
- package/dist/esm/components/Suggestion/index.js +56 -0
- package/dist/esm/components/Switch/Switch.js +18 -0
- package/dist/esm/components/Table/Table.js +35 -0
- package/dist/esm/components/Table/TableBody.js +20 -0
- package/dist/esm/components/Table/TableCell.js +15 -0
- package/dist/esm/components/Table/TableFoot.js +20 -0
- package/dist/esm/components/Table/TableHead.js +20 -0
- package/dist/esm/components/Table/TableHeaderCell.js +15 -0
- package/dist/esm/components/Table/TableRow.js +18 -0
- package/dist/esm/components/Table/index.js +51 -0
- package/dist/esm/components/Tabs/Tabs.js +40 -0
- package/dist/esm/components/Tabs/TabsList.js +21 -0
- package/dist/esm/components/Tabs/TabsPanel.js +29 -0
- package/dist/esm/components/Tabs/TabsTab.js +19 -0
- package/dist/esm/components/Tabs/index.js +31 -0
- package/dist/esm/components/Tag/Tag.js +16 -0
- package/dist/esm/components/Textarea/Textarea.js +16 -0
- package/dist/esm/components/Textfield/Textfield.js +25 -0
- package/dist/esm/components/Timeline/Timeline.js +23 -0
- package/dist/esm/components/Timeline/TimelineItem.js +21 -0
- package/dist/esm/components/Timeline/index.js +24 -0
- package/dist/esm/components/ToggleGroup/ToggleGroup.js +126 -0
- package/dist/esm/components/ToggleGroup/ToggleGroupItem.js +18 -0
- package/dist/esm/components/ToggleGroup/index.js +20 -0
- package/dist/esm/components/ToggleGroup/useToggleGroupitem.js +30 -0
- package/dist/esm/components/Tooltip/Tooltip.js +120 -0
- package/dist/esm/components/ValidationMessage/ValidationMessage.js +18 -0
- package/dist/esm/index.js +112 -0
- package/dist/esm/layouts/Container/Container.js +17 -0
- package/dist/esm/layouts/Grid/GridCol.js +10 -0
- package/dist/esm/layouts/Grid/GridRow.js +10 -0
- package/dist/esm/utilities/RovingFocus/RovingFocusItem.js +68 -0
- package/dist/esm/utilities/RovingFocus/RovingFocusRoot.js +69 -0
- package/dist/esm/utilities/RovingFocus/useRovingFocus.js +41 -0
- package/dist/esm/utilities/hooks/useCheckboxGroup/useCheckboxGroup.js +119 -0
- package/dist/esm/utilities/hooks/useDebounceCallback/useDebounceCallback.js +25 -0
- package/dist/esm/utilities/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.js +7 -0
- package/dist/esm/utilities/hooks/useMediaQuery/useMediaQuery.js +47 -0
- package/dist/esm/utilities/hooks/useMergeRefs/useMergeRefs.js +55 -0
- package/dist/esm/utilities/hooks/usePagination/usePagination.js +95 -0
- package/dist/esm/utilities/hooks/useRadioGroup/useRadioGroup.js +97 -0
- package/dist/esm/utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.js +46 -0
- package/dist/esm/utilities/omit/omit.js +26 -0
- package/dist/react-types.d.ts +11 -0
- package/dist/types/colors.d.ts +24 -0
- package/dist/types/colors.d.ts.map +1 -0
- package/dist/types/components/Alert/Alert.d.ts +27 -0
- package/dist/types/components/Alert/Alert.d.ts.map +1 -0
- package/dist/types/components/Alert/index.d.ts +3 -0
- package/dist/types/components/Alert/index.d.ts.map +1 -0
- package/dist/types/components/Avatar/Avatar.d.ts +72 -0
- package/dist/types/components/Avatar/Avatar.d.ts.map +1 -0
- package/dist/types/components/Avatar/index.d.ts +3 -0
- package/dist/types/components/Avatar/index.d.ts.map +1 -0
- package/dist/types/components/Badge/Badge.d.ts +58 -0
- package/dist/types/components/Badge/Badge.d.ts.map +1 -0
- package/dist/types/components/Badge/BadgePosition.d.ts +41 -0
- package/dist/types/components/Badge/BadgePosition.d.ts.map +1 -0
- package/dist/types/components/Badge/index.d.ts +23 -0
- package/dist/types/components/Badge/index.d.ts.map +1 -0
- package/dist/types/components/Breadcrumbs/Breadcrumbs.d.ts +36 -0
- package/dist/types/components/Breadcrumbs/Breadcrumbs.d.ts.map +1 -0
- package/dist/types/components/Breadcrumbs/BreadcrumbsItem.d.ts +4 -0
- package/dist/types/components/Breadcrumbs/BreadcrumbsItem.d.ts.map +1 -0
- package/dist/types/components/Breadcrumbs/BreadcrumbsLink.d.ts +7 -0
- package/dist/types/components/Breadcrumbs/BreadcrumbsLink.d.ts.map +1 -0
- package/dist/types/components/Breadcrumbs/BreadcrumbsList.d.ts +4 -0
- package/dist/types/components/Breadcrumbs/BreadcrumbsList.d.ts.map +1 -0
- package/dist/types/components/Breadcrumbs/index.d.ts +37 -0
- package/dist/types/components/Breadcrumbs/index.d.ts.map +1 -0
- package/dist/types/components/Button/Button.d.ts +77 -0
- package/dist/types/components/Button/Button.d.ts.map +1 -0
- package/dist/types/components/Button/index.d.ts +3 -0
- package/dist/types/components/Button/index.d.ts.map +1 -0
- package/dist/types/components/Card/Card.d.ts +44 -0
- package/dist/types/components/Card/Card.d.ts.map +1 -0
- package/dist/types/components/Card/CardBlock.d.ts +16 -0
- package/dist/types/components/Card/CardBlock.d.ts.map +1 -0
- package/dist/types/components/Card/index.d.ts +24 -0
- package/dist/types/components/Card/index.d.ts.map +1 -0
- package/dist/types/components/Checkbox/Checkbox.d.ts +34 -0
- package/dist/types/components/Checkbox/Checkbox.d.ts.map +1 -0
- package/dist/types/components/Checkbox/index.d.ts +3 -0
- package/dist/types/components/Checkbox/index.d.ts.map +1 -0
- package/dist/types/components/Chip/Chips.d.ts +43 -0
- package/dist/types/components/Chip/Chips.d.ts.map +1 -0
- package/dist/types/components/Chip/index.d.ts +18 -0
- package/dist/types/components/Chip/index.d.ts.map +1 -0
- package/dist/types/components/Details/Details.d.ts +50 -0
- package/dist/types/components/Details/Details.d.ts.map +1 -0
- package/dist/types/components/Details/DetailsContent.d.ts +10 -0
- package/dist/types/components/Details/DetailsContent.d.ts.map +1 -0
- package/dist/types/components/Details/DetailsSummary.d.ts +16 -0
- package/dist/types/components/Details/DetailsSummary.d.ts.map +1 -0
- package/dist/types/components/Details/index.d.ts +22 -0
- package/dist/types/components/Details/index.d.ts.map +1 -0
- package/dist/types/components/Dialog/Dialog.d.ts +95 -0
- package/dist/types/components/Dialog/Dialog.d.ts.map +1 -0
- package/dist/types/components/Dialog/DialogBlock.d.ts +32 -0
- package/dist/types/components/Dialog/DialogBlock.d.ts.map +1 -0
- package/dist/types/components/Dialog/DialogTrigger.d.ts +23 -0
- package/dist/types/components/Dialog/DialogTrigger.d.ts.map +1 -0
- package/dist/types/components/Dialog/DialogTriggerContext.d.ts +21 -0
- package/dist/types/components/Dialog/DialogTriggerContext.d.ts.map +1 -0
- package/dist/types/components/Dialog/index.d.ts +46 -0
- package/dist/types/components/Dialog/index.d.ts.map +1 -0
- package/dist/types/components/Divider/Divider.d.ts +10 -0
- package/dist/types/components/Divider/Divider.d.ts.map +1 -0
- package/dist/types/components/Divider/index.d.ts +3 -0
- package/dist/types/components/Divider/index.d.ts.map +1 -0
- package/dist/types/components/Dropdown/Dropdown.d.ts +46 -0
- package/dist/types/components/Dropdown/Dropdown.d.ts.map +1 -0
- package/dist/types/components/Dropdown/DropdownButton.d.ts +4 -0
- package/dist/types/components/Dropdown/DropdownButton.d.ts.map +1 -0
- package/dist/types/components/Dropdown/DropdownHeading.d.ts +9 -0
- package/dist/types/components/Dropdown/DropdownHeading.d.ts.map +1 -0
- package/dist/types/components/Dropdown/DropdownItem.d.ts +4 -0
- package/dist/types/components/Dropdown/DropdownItem.d.ts.map +1 -0
- package/dist/types/components/Dropdown/DropdownList.d.ts +4 -0
- package/dist/types/components/Dropdown/DropdownList.d.ts.map +1 -0
- package/dist/types/components/Dropdown/DropdownTrigger.d.ts +4 -0
- package/dist/types/components/Dropdown/DropdownTrigger.d.ts.map +1 -0
- package/dist/types/components/Dropdown/DropdownTriggerContext.d.ts +25 -0
- package/dist/types/components/Dropdown/DropdownTriggerContext.d.ts.map +1 -0
- package/dist/types/components/Dropdown/index.d.ts +48 -0
- package/dist/types/components/Dropdown/index.d.ts.map +1 -0
- package/dist/types/components/ErrorSummary/ErrorSummary.d.ts +31 -0
- package/dist/types/components/ErrorSummary/ErrorSummary.d.ts.map +1 -0
- package/dist/types/components/ErrorSummary/ErrorSummaryHeading.d.ts +9 -0
- package/dist/types/components/ErrorSummary/ErrorSummaryHeading.d.ts.map +1 -0
- package/dist/types/components/ErrorSummary/ErrorSummaryItem.d.ts +12 -0
- package/dist/types/components/ErrorSummary/ErrorSummaryItem.d.ts.map +1 -0
- package/dist/types/components/ErrorSummary/ErrorSummaryLink.d.ts +10 -0
- package/dist/types/components/ErrorSummary/ErrorSummaryLink.d.ts.map +1 -0
- package/dist/types/components/ErrorSummary/ErrorSummaryList.d.ts +6 -0
- package/dist/types/components/ErrorSummary/ErrorSummaryList.d.ts.map +1 -0
- package/dist/types/components/ErrorSummary/index.d.ts +47 -0
- package/dist/types/components/ErrorSummary/index.d.ts.map +1 -0
- package/dist/types/components/Field/Field.d.ts +28 -0
- package/dist/types/components/Field/Field.d.ts.map +1 -0
- package/dist/types/components/Field/FieldAffix.d.ts +27 -0
- package/dist/types/components/Field/FieldAffix.d.ts.map +1 -0
- package/dist/types/components/Field/FieldCounter.d.ts +58 -0
- package/dist/types/components/Field/FieldCounter.d.ts.map +1 -0
- package/dist/types/components/Field/FieldDescription.d.ts +4 -0
- package/dist/types/components/Field/FieldDescription.d.ts.map +1 -0
- package/dist/types/components/Field/fieldObserver.d.ts +5 -0
- package/dist/types/components/Field/fieldObserver.d.ts.map +1 -0
- package/dist/types/components/Field/index.d.ts +35 -0
- package/dist/types/components/Field/index.d.ts.map +1 -0
- package/dist/types/components/Fieldset/Fieldset.d.ts +20 -0
- package/dist/types/components/Fieldset/Fieldset.d.ts.map +1 -0
- package/dist/types/components/Fieldset/FieldsetDescription.d.ts +16 -0
- package/dist/types/components/Fieldset/FieldsetDescription.d.ts.map +1 -0
- package/dist/types/components/Fieldset/FieldsetLegend.d.ts +11 -0
- package/dist/types/components/Fieldset/FieldsetLegend.d.ts.map +1 -0
- package/dist/types/components/Fieldset/index.d.ts +30 -0
- package/dist/types/components/Fieldset/index.d.ts.map +1 -0
- package/dist/types/components/Heading/Heading.d.ts +52 -0
- package/dist/types/components/Heading/Heading.d.ts.map +1 -0
- package/dist/types/components/Heading/index.d.ts +3 -0
- package/dist/types/components/Heading/index.d.ts.map +1 -0
- package/dist/types/components/InfoCard/InfoCard.d.ts +32 -0
- package/dist/types/components/InfoCard/InfoCard.d.ts.map +1 -0
- package/dist/types/components/InfoCard/index.d.ts +3 -0
- package/dist/types/components/InfoCard/index.d.ts.map +1 -0
- package/dist/types/components/Input/Input.d.ts +62 -0
- package/dist/types/components/Input/Input.d.ts.map +1 -0
- package/dist/types/components/Input/index.d.ts +3 -0
- package/dist/types/components/Input/index.d.ts.map +1 -0
- package/dist/types/components/Label/Label.d.ts +33 -0
- package/dist/types/components/Label/Label.d.ts.map +1 -0
- package/dist/types/components/Label/index.d.ts +3 -0
- package/dist/types/components/Label/index.d.ts.map +1 -0
- package/dist/types/components/Link/Link.d.ts +32 -0
- package/dist/types/components/Link/Link.d.ts.map +1 -0
- package/dist/types/components/Link/index.d.ts +3 -0
- package/dist/types/components/Link/index.d.ts.map +1 -0
- package/dist/types/components/List/ListItem.d.ts +16 -0
- package/dist/types/components/List/ListItem.d.ts.map +1 -0
- package/dist/types/components/List/Lists.d.ts +47 -0
- package/dist/types/components/List/Lists.d.ts.map +1 -0
- package/dist/types/components/List/index.d.ts +17 -0
- package/dist/types/components/List/index.d.ts.map +1 -0
- package/dist/types/components/Pagination/Pagination.d.ts +46 -0
- package/dist/types/components/Pagination/Pagination.d.ts.map +1 -0
- package/dist/types/components/Pagination/PaginationButton.d.ts +25 -0
- package/dist/types/components/Pagination/PaginationButton.d.ts.map +1 -0
- package/dist/types/components/Pagination/PaginationItem.d.ts +26 -0
- package/dist/types/components/Pagination/PaginationItem.d.ts.map +1 -0
- package/dist/types/components/Pagination/PaginationList.d.ts +28 -0
- package/dist/types/components/Pagination/PaginationList.d.ts.map +1 -0
- package/dist/types/components/Pagination/index.d.ts +41 -0
- package/dist/types/components/Pagination/index.d.ts.map +1 -0
- package/dist/types/components/Paragraph/Paragraph.d.ts +41 -0
- package/dist/types/components/Paragraph/Paragraph.d.ts.map +1 -0
- package/dist/types/components/Paragraph/index.d.ts +3 -0
- package/dist/types/components/Paragraph/index.d.ts.map +1 -0
- package/dist/types/components/Popover/Popover.d.ts +123 -0
- package/dist/types/components/Popover/Popover.d.ts.map +1 -0
- package/dist/types/components/Popover/PopoverTrigger.d.ts +44 -0
- package/dist/types/components/Popover/PopoverTrigger.d.ts.map +1 -0
- package/dist/types/components/Popover/PopoverTriggerContext.d.ts +24 -0
- package/dist/types/components/Popover/PopoverTriggerContext.d.ts.map +1 -0
- package/dist/types/components/Popover/index.d.ts +35 -0
- package/dist/types/components/Popover/index.d.ts.map +1 -0
- package/dist/types/components/Radio/Radio.d.ts +34 -0
- package/dist/types/components/Radio/Radio.d.ts.map +1 -0
- package/dist/types/components/Radio/index.d.ts +3 -0
- package/dist/types/components/Radio/index.d.ts.map +1 -0
- package/dist/types/components/Search/Search.d.ts +20 -0
- package/dist/types/components/Search/Search.d.ts.map +1 -0
- package/dist/types/components/Search/SearchButton.d.ts +33 -0
- package/dist/types/components/Search/SearchButton.d.ts.map +1 -0
- package/dist/types/components/Search/SearchClear.d.ts +32 -0
- package/dist/types/components/Search/SearchClear.d.ts.map +1 -0
- package/dist/types/components/Search/SearchInput.d.ts +12 -0
- package/dist/types/components/Search/SearchInput.d.ts.map +1 -0
- package/dist/types/components/Search/index.d.ts +39 -0
- package/dist/types/components/Search/index.d.ts.map +1 -0
- package/dist/types/components/Select/Select.d.ts +38 -0
- package/dist/types/components/Select/Select.d.ts.map +1 -0
- package/dist/types/components/Select/SelectOptgroup.d.ts +27 -0
- package/dist/types/components/Select/SelectOptgroup.d.ts.map +1 -0
- package/dist/types/components/Select/SelectOption.d.ts +25 -0
- package/dist/types/components/Select/SelectOption.d.ts.map +1 -0
- package/dist/types/components/Select/index.d.ts +27 -0
- package/dist/types/components/Select/index.d.ts.map +1 -0
- package/dist/types/components/Skeleton/Skeleton.d.ts +37 -0
- package/dist/types/components/Skeleton/Skeleton.d.ts.map +1 -0
- package/dist/types/components/Skeleton/index.d.ts +3 -0
- package/dist/types/components/Skeleton/index.d.ts.map +1 -0
- package/dist/types/components/SkipLink/SkipLink.d.ts +31 -0
- package/dist/types/components/SkipLink/SkipLink.d.ts.map +1 -0
- package/dist/types/components/SkipLink/index.d.ts +3 -0
- package/dist/types/components/SkipLink/index.d.ts.map +1 -0
- package/dist/types/components/Spinner/Spinner.d.ts +25 -0
- package/dist/types/components/Spinner/Spinner.d.ts.map +1 -0
- package/dist/types/components/Spinner/index.d.ts +3 -0
- package/dist/types/components/Spinner/index.d.ts.map +1 -0
- package/dist/types/components/Suggestion/Suggestion.d.ts +199 -0
- package/dist/types/components/Suggestion/Suggestion.d.ts.map +1 -0
- package/dist/types/components/Suggestion/SuggestionChips.d.ts +11 -0
- package/dist/types/components/Suggestion/SuggestionChips.d.ts.map +1 -0
- package/dist/types/components/Suggestion/SuggestionClear.d.ts +28 -0
- package/dist/types/components/Suggestion/SuggestionClear.d.ts.map +1 -0
- package/dist/types/components/Suggestion/SuggestionEmpty.d.ts +15 -0
- package/dist/types/components/Suggestion/SuggestionEmpty.d.ts.map +1 -0
- package/dist/types/components/Suggestion/SuggestionInput.d.ts +33 -0
- package/dist/types/components/Suggestion/SuggestionInput.d.ts.map +1 -0
- package/dist/types/components/Suggestion/SuggestionList.d.ts +40 -0
- package/dist/types/components/Suggestion/SuggestionList.d.ts.map +1 -0
- package/dist/types/components/Suggestion/SuggestionOption.d.ts +5 -0
- package/dist/types/components/Suggestion/SuggestionOption.d.ts.map +1 -0
- package/dist/types/components/Suggestion/index.d.ts +138 -0
- package/dist/types/components/Suggestion/index.d.ts.map +1 -0
- package/dist/types/components/Switch/Switch.d.ts +36 -0
- package/dist/types/components/Switch/Switch.d.ts.map +1 -0
- package/dist/types/components/Switch/index.d.ts +3 -0
- package/dist/types/components/Switch/index.d.ts.map +1 -0
- package/dist/types/components/Table/Table.d.ts +72 -0
- package/dist/types/components/Table/Table.d.ts.map +1 -0
- package/dist/types/components/Table/TableBody.d.ts +15 -0
- package/dist/types/components/Table/TableBody.d.ts.map +1 -0
- package/dist/types/components/Table/TableCell.d.ts +10 -0
- package/dist/types/components/Table/TableCell.d.ts.map +1 -0
- package/dist/types/components/Table/TableFoot.d.ts +15 -0
- package/dist/types/components/Table/TableFoot.d.ts.map +1 -0
- package/dist/types/components/Table/TableHead.d.ts +15 -0
- package/dist/types/components/Table/TableHead.d.ts.map +1 -0
- package/dist/types/components/Table/TableHeaderCell.d.ts +23 -0
- package/dist/types/components/Table/TableHeaderCell.d.ts.map +1 -0
- package/dist/types/components/Table/TableRow.d.ts +13 -0
- package/dist/types/components/Table/TableRow.d.ts.map +1 -0
- package/dist/types/components/Table/index.d.ts +56 -0
- package/dist/types/components/Table/index.d.ts.map +1 -0
- package/dist/types/components/Tabs/Tabs.d.ts +59 -0
- package/dist/types/components/Tabs/Tabs.d.ts.map +1 -0
- package/dist/types/components/Tabs/TabsList.d.ts +13 -0
- package/dist/types/components/Tabs/TabsList.d.ts.map +1 -0
- package/dist/types/components/Tabs/TabsPanel.d.ts +22 -0
- package/dist/types/components/Tabs/TabsPanel.d.ts.map +1 -0
- package/dist/types/components/Tabs/TabsTab.d.ts +20 -0
- package/dist/types/components/Tabs/TabsTab.d.ts.map +1 -0
- package/dist/types/components/Tabs/index.d.ts +37 -0
- package/dist/types/components/Tabs/index.d.ts.map +1 -0
- package/dist/types/components/Tag/Tag.d.ts +23 -0
- package/dist/types/components/Tag/Tag.d.ts.map +1 -0
- package/dist/types/components/Tag/index.d.ts +3 -0
- package/dist/types/components/Tag/index.d.ts.map +1 -0
- package/dist/types/components/Textarea/Textarea.d.ts +11 -0
- package/dist/types/components/Textarea/Textarea.d.ts.map +1 -0
- package/dist/types/components/Textarea/index.d.ts +3 -0
- package/dist/types/components/Textarea/index.d.ts.map +1 -0
- package/dist/types/components/Textfield/Textfield.d.ts +74 -0
- package/dist/types/components/Textfield/Textfield.d.ts.map +1 -0
- package/dist/types/components/Textfield/index.d.ts +3 -0
- package/dist/types/components/Textfield/index.d.ts.map +1 -0
- package/dist/types/components/Timeline/Timeline.d.ts +35 -0
- package/dist/types/components/Timeline/Timeline.d.ts.map +1 -0
- package/dist/types/components/Timeline/TimelineItem.d.ts +21 -0
- package/dist/types/components/Timeline/TimelineItem.d.ts.map +1 -0
- package/dist/types/components/Timeline/index.d.ts +27 -0
- package/dist/types/components/Timeline/index.d.ts.map +1 -0
- package/dist/types/components/ToggleGroup/ToggleGroup.d.ts +67 -0
- package/dist/types/components/ToggleGroup/ToggleGroup.d.ts.map +1 -0
- package/dist/types/components/ToggleGroup/ToggleGroupItem.d.ts +21 -0
- package/dist/types/components/ToggleGroup/ToggleGroupItem.d.ts.map +1 -0
- package/dist/types/components/ToggleGroup/index.d.ts +26 -0
- package/dist/types/components/ToggleGroup/index.d.ts.map +1 -0
- package/dist/types/components/ToggleGroup/useToggleGroupitem.d.ts +11 -0
- package/dist/types/components/ToggleGroup/useToggleGroupitem.d.ts.map +1 -0
- package/dist/types/components/Tooltip/Tooltip.d.ts +63 -0
- package/dist/types/components/Tooltip/Tooltip.d.ts.map +1 -0
- package/dist/types/components/Tooltip/index.d.ts +3 -0
- package/dist/types/components/Tooltip/index.d.ts.map +1 -0
- package/dist/types/components/ValidationMessage/ValidationMessage.d.ts +35 -0
- package/dist/types/components/ValidationMessage/ValidationMessage.d.ts.map +1 -0
- package/dist/types/components/ValidationMessage/index.d.ts +3 -0
- package/dist/types/components/ValidationMessage/index.d.ts.map +1 -0
- package/dist/types/components/index.d.ts +42 -0
- package/dist/types/components/index.d.ts.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/layouts/Container/Container.d.ts +10 -0
- package/dist/types/layouts/Container/Container.d.ts.map +1 -0
- package/dist/types/layouts/Container/index.d.ts +2 -0
- package/dist/types/layouts/Container/index.d.ts.map +1 -0
- package/dist/types/layouts/Grid/GridCol.d.ts +20 -0
- package/dist/types/layouts/Grid/GridCol.d.ts.map +1 -0
- package/dist/types/layouts/Grid/GridRow.d.ts +6 -0
- package/dist/types/layouts/Grid/GridRow.d.ts.map +1 -0
- package/dist/types/layouts/Grid/index.d.ts +5 -0
- package/dist/types/layouts/Grid/index.d.ts.map +1 -0
- package/dist/types/layouts/index.d.ts +3 -0
- package/dist/types/layouts/index.d.ts.map +1 -0
- package/dist/types/types.d.ts +28 -0
- package/dist/types/types.d.ts.map +1 -0
- package/dist/types/utilities/RovingFocus/RovingFocusItem.d.ts +16 -0
- package/dist/types/utilities/RovingFocus/RovingFocusItem.d.ts.map +1 -0
- package/dist/types/utilities/RovingFocus/RovingFocusRoot.d.ts +33 -0
- package/dist/types/utilities/RovingFocus/RovingFocusRoot.d.ts.map +1 -0
- package/dist/types/utilities/RovingFocus/index.d.ts +4 -0
- package/dist/types/utilities/RovingFocus/index.d.ts.map +1 -0
- package/dist/types/utilities/RovingFocus/useRovingFocus.d.ts +295 -0
- package/dist/types/utilities/RovingFocus/useRovingFocus.d.ts.map +1 -0
- package/dist/types/utilities/hooks/index.d.ts +12 -0
- package/dist/types/utilities/hooks/index.d.ts.map +1 -0
- package/dist/types/utilities/hooks/useCheckboxGroup/useCheckboxGroup.d.ts +64 -0
- package/dist/types/utilities/hooks/useCheckboxGroup/useCheckboxGroup.d.ts.map +1 -0
- package/dist/types/utilities/hooks/useDebounceCallback/useDebounceCallback.d.ts +4 -0
- package/dist/types/utilities/hooks/useDebounceCallback/useDebounceCallback.d.ts.map +1 -0
- package/dist/types/utilities/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.d.ts +3 -0
- package/dist/types/utilities/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.d.ts.map +1 -0
- package/dist/types/utilities/hooks/useMediaQuery/useMediaQuery.d.ts +7 -0
- package/dist/types/utilities/hooks/useMediaQuery/useMediaQuery.d.ts.map +1 -0
- package/dist/types/utilities/hooks/useMergeRefs/useMergeRefs.d.ts +6 -0
- package/dist/types/utilities/hooks/useMergeRefs/useMergeRefs.d.ts.map +1 -0
- package/dist/types/utilities/hooks/usePagination/usePagination.d.ts +82 -0
- package/dist/types/utilities/hooks/usePagination/usePagination.d.ts.map +1 -0
- package/dist/types/utilities/hooks/useRadioGroup/useRadioGroup.d.ts +56 -0
- package/dist/types/utilities/hooks/useRadioGroup/useRadioGroup.d.ts.map +1 -0
- package/dist/types/utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.d.ts +14 -0
- package/dist/types/utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.d.ts.map +1 -0
- package/dist/types/utilities/index.d.ts +5 -0
- package/dist/types/utilities/index.d.ts.map +1 -0
- package/dist/types/utilities/omit/omit.d.ts +11 -0
- package/dist/types/utilities/omit/omit.d.ts.map +1 -0
- package/dist/types/utilities/types.d.ts +6 -0
- package/dist/types/utilities/types.d.ts.map +1 -0
- package/package.json +83 -0
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var react = require('react');
|
|
6
|
+
var react$1 = require('@floating-ui/react');
|
|
7
|
+
var Tabs = require('./Tabs.js');
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* A single content item in a Tabs component.
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* <Tabs.Panel value='1'>content 1</Tabs.Panel>
|
|
14
|
+
*/
|
|
15
|
+
const TabsPanel = react.forwardRef(function TabsPanel({ children, value, ...rest }, ref) {
|
|
16
|
+
const { value: tabsValue } = react.useContext(Tabs.Context);
|
|
17
|
+
const active = value === tabsValue;
|
|
18
|
+
const [hasTabbableElement, setHasTabbableElement] = react.useState(false);
|
|
19
|
+
const internalRef = react.useRef(null);
|
|
20
|
+
const mergedRef = react$1.useMergeRefs([ref, internalRef]);
|
|
21
|
+
/* Check if the panel has any tabbable elements */
|
|
22
|
+
react.useEffect(() => {
|
|
23
|
+
if (!internalRef.current)
|
|
24
|
+
return;
|
|
25
|
+
const tabbableElements = internalRef.current.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])');
|
|
26
|
+
setHasTabbableElement(tabbableElements.length > 0);
|
|
27
|
+
}, [children]);
|
|
28
|
+
return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: active && (jsxRuntime.jsx("div", { ref: mergedRef, role: 'tabpanel', tabIndex: hasTabbableElement ? undefined : 0, ...rest, children: children })) }));
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
exports.TabsPanel = TabsPanel;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var react = require('react');
|
|
6
|
+
var RovingFocusItem = require('../../utilities/RovingFocus/RovingFocusItem.js');
|
|
7
|
+
var Tabs = require('./Tabs.js');
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* A single item in a Tabs component.
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* <Tabs.Tab value='1'>Tab 1</Tabs.Tab>
|
|
14
|
+
*/
|
|
15
|
+
const TabsTab = react.forwardRef(function TabsTab({ value, id, ...rest }, ref) {
|
|
16
|
+
const tabs = react.useContext(Tabs.Context);
|
|
17
|
+
const buttonId = id ?? `tab-${react.useId()}`;
|
|
18
|
+
return (jsxRuntime.jsx(RovingFocusItem.RovingFocusItem, { value: value, ...rest, asChild: true, children: jsxRuntime.jsx("button", { ...rest, "aria-selected": tabs.value === value, id: buttonId, onClick: () => tabs.onChange?.(value), ref: ref, role: 'tab', type: 'button' }) }));
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
exports.TabsTab = TabsTab;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var Tabs$1 = require('./Tabs.js');
|
|
5
|
+
var TabsList = require('./TabsList.js');
|
|
6
|
+
var TabsPanel = require('./TabsPanel.js');
|
|
7
|
+
var TabsTab = require('./TabsTab.js');
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Display a group of tabs that can be toggled between.
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* <Tabs onChange={(value) => console.log(value)}>
|
|
14
|
+
* <Tabs.List>
|
|
15
|
+
* <Tabs.Tab value='1'>Tab 1</Tabs.Tab>
|
|
16
|
+
* <Tabs.Tab value='2'>Tab 2</Tabs.Tab>
|
|
17
|
+
* <Tabs.Tab value='3'>Tab 3</Tabs.Tab>
|
|
18
|
+
* </Tabs.List>
|
|
19
|
+
* <Tabs.Panel value='1'>content 1</Tabs.Panel>
|
|
20
|
+
* <Tabs.Panel value='2'>content 2</Tabs.Panel>
|
|
21
|
+
* <Tabs.Panel value='3'>content 3</Tabs.Panel>
|
|
22
|
+
* </Tabs>
|
|
23
|
+
*/
|
|
24
|
+
const Tabs = Object.assign(Tabs$1.Tabs, {
|
|
25
|
+
List: TabsList.TabsList,
|
|
26
|
+
Tab: TabsTab.TabsTab,
|
|
27
|
+
Panel: TabsPanel.TabsPanel,
|
|
28
|
+
});
|
|
29
|
+
Tabs.Tab.displayName = 'Tabs.Tab';
|
|
30
|
+
Tabs.List.displayName = 'Tabs.List';
|
|
31
|
+
Tabs.Panel.displayName = 'Tabs.Panel';
|
|
32
|
+
|
|
33
|
+
exports.TabsList = TabsList.TabsList;
|
|
34
|
+
exports.TabsPanel = TabsPanel.TabsPanel;
|
|
35
|
+
exports.TabsTab = TabsTab.TabsTab;
|
|
36
|
+
exports.Tabs = Tabs;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var cl = require('clsx/lite');
|
|
6
|
+
var react = require('react');
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Use `Tag` to display categories or statuses.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* <Tag>Melk</Tag>
|
|
13
|
+
*/
|
|
14
|
+
const Tag = react.forwardRef(function Tag({ className, ...rest }, ref) {
|
|
15
|
+
return jsxRuntime.jsx("span", { className: cl('ds-tag', className), ref: ref, ...rest });
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
exports.Tag = Tag;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var cl = require('clsx/lite');
|
|
6
|
+
var react = require('react');
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Native HTML textarea element.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* <Textarea />
|
|
13
|
+
*/
|
|
14
|
+
const Textarea = react.forwardRef(function Textarea({ className, ...rest }, ref) {
|
|
15
|
+
return (jsxRuntime.jsx("textarea", { className: cl('ds-input', className), ref: ref, ...rest }));
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
exports.Textarea = Textarea;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var react = require('react');
|
|
6
|
+
var index = require('../Field/index.js');
|
|
7
|
+
var Label = require('../Label/Label.js');
|
|
8
|
+
var FieldDescription = require('../Field/FieldDescription.js');
|
|
9
|
+
var FieldAffix = require('../Field/FieldAffix.js');
|
|
10
|
+
var Textarea = require('../Textarea/Textarea.js');
|
|
11
|
+
var Input = require('../Input/Input.js');
|
|
12
|
+
var ValidationMessage = require('../ValidationMessage/ValidationMessage.js');
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Composed text input component using `Field`
|
|
16
|
+
*
|
|
17
|
+
* `classname` & `style` are passed to the wrapper elements.
|
|
18
|
+
*
|
|
19
|
+
* Rest props are passed to the `Input` or `Textarea` component.
|
|
20
|
+
* @example
|
|
21
|
+
* <Textfield label="Textfield label">
|
|
22
|
+
*/
|
|
23
|
+
const Textfield = react.forwardRef(function Textfield({ label, description, error, multiline, prefix, suffix, 'data-size': size, counter, style, className, ...rest }, ref) {
|
|
24
|
+
return (jsxRuntime.jsxs(index.Field, { className: className, "data-size": size, style: style, children: [!!label && jsxRuntime.jsx(Label.Label, { children: label }), !!description && jsxRuntime.jsx(FieldDescription.FieldDescription, { children: description }), jsxRuntime.jsxs(FieldAffix.FieldAffixes, { children: [prefix === undefined || jsxRuntime.jsx(FieldAffix.FieldAffix, { children: prefix }), multiline === true ? (jsxRuntime.jsx(Textarea.Textarea, { ref: ref, "aria-invalid": Boolean(error) || undefined, ...rest })) : (jsxRuntime.jsx(Input.Input, { ref: ref, "aria-invalid": Boolean(error) || undefined, ...rest })), suffix === undefined || jsxRuntime.jsx(FieldAffix.FieldAffix, { children: suffix })] }), !!error && jsxRuntime.jsx(ValidationMessage.ValidationMessage, { children: error }), !!counter && (jsxRuntime.jsx(index.Field.Counter, { ...(typeof counter === 'number' ? { limit: counter } : counter) }))] }));
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
exports.Textfield = Textfield;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var cl = require('clsx/lite');
|
|
6
|
+
var react = require('react');
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Timeline component for displaying a process or sequence of steps.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* <Timeline>
|
|
13
|
+
* <Timeline.Item>
|
|
14
|
+
* <Details>
|
|
15
|
+
* <Details.Summary>Step 1</Details.Summary>
|
|
16
|
+
* <Details.Content>Content</Details.Content>
|
|
17
|
+
* </Details>
|
|
18
|
+
* </Timeline.Item>
|
|
19
|
+
* </Timeline>
|
|
20
|
+
*/
|
|
21
|
+
const Timeline = react.forwardRef(function Timeline({ className, ...rest }, ref) {
|
|
22
|
+
return (jsxRuntime.jsx("ol", { className: cl('ds-timeline', className), ref: ref, ...rest }));
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
exports.Timeline = Timeline;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var cl = require('clsx/lite');
|
|
6
|
+
var react = require('react');
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Timeline item/chapter component, represents a single step in the timeline.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* <Timeline.Item>
|
|
13
|
+
* <Details>
|
|
14
|
+
* <Details.Summary>Step heading</Details.Summary>
|
|
15
|
+
* <Details.Content>Step content</Details.Content>
|
|
16
|
+
* </Details>
|
|
17
|
+
* </Timeline.Item>
|
|
18
|
+
*/
|
|
19
|
+
const TimelineItem = react.forwardRef(function TimelineItem({ className, ...rest }, ref) {
|
|
20
|
+
return (jsxRuntime.jsx("li", { className: cl('ds-timeline__item', className), ref: ref, ...rest }));
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
exports.TimelineItem = TimelineItem;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var Timeline$1 = require('./Timeline.js');
|
|
5
|
+
var TimelineItem = require('./TimelineItem.js');
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Timeline component for displaying a process or sequence of steps.
|
|
9
|
+
* Compose with `Details` for expandable chapters.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* <Timeline>
|
|
13
|
+
* <Timeline.Item>
|
|
14
|
+
* <Details>
|
|
15
|
+
* <Details.Summary>Step 1</Details.Summary>
|
|
16
|
+
* <Details.Content>Content here</Details.Content>
|
|
17
|
+
* </Details>
|
|
18
|
+
* </Timeline.Item>
|
|
19
|
+
* </Timeline>
|
|
20
|
+
*/
|
|
21
|
+
const Timeline = Object.assign(Timeline$1.Timeline, {
|
|
22
|
+
Item: TimelineItem.TimelineItem,
|
|
23
|
+
});
|
|
24
|
+
Timeline.Item.displayName = 'Timeline.Item';
|
|
25
|
+
|
|
26
|
+
exports.TimelineItem = TimelineItem.TimelineItem;
|
|
27
|
+
exports.Timeline = Timeline;
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var cl = require('clsx/lite');
|
|
6
|
+
var react = require('react');
|
|
7
|
+
var RovingFocusRoot = require('../../utilities/RovingFocus/RovingFocusRoot.js');
|
|
8
|
+
|
|
9
|
+
const ToggleGroupContext = react.createContext({});
|
|
10
|
+
/**
|
|
11
|
+
* Display a group of buttons that can be toggled between.
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* <ToggleGroup onChange={(value) => console.log(value)}>
|
|
15
|
+
* <ToggleGroup.Item value='1'>Toggle 1</ToggleGroup.Item>
|
|
16
|
+
* <ToggleGroup.Item value='2'>Toggle 2</ToggleGroup.Item>
|
|
17
|
+
* <ToggleGroup.Item value='3'>Toggle 3</ToggleGroup.Item>
|
|
18
|
+
* </ToggleGroup>
|
|
19
|
+
*/
|
|
20
|
+
const ToggleGroup = react.forwardRef(function ToggleGroup({ children, value, defaultValue, onChange, name, animated = true, className, ...rest }, ref) {
|
|
21
|
+
const nameId = react.useId();
|
|
22
|
+
const isControlled = value !== undefined;
|
|
23
|
+
const [uncontrolledValue, setUncontrolledValue] = react.useState(defaultValue);
|
|
24
|
+
const currentValue = isControlled ? value : uncontrolledValue;
|
|
25
|
+
const containerRef = react.useRef(null);
|
|
26
|
+
const indicatorRef = react.useRef(null);
|
|
27
|
+
let onValueChange = onChange;
|
|
28
|
+
if (!isControlled) {
|
|
29
|
+
onValueChange = (newValue) => {
|
|
30
|
+
setUncontrolledValue(newValue);
|
|
31
|
+
onChange?.(newValue);
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
const updateIndicator = react.useCallback(() => {
|
|
35
|
+
if (!animated)
|
|
36
|
+
return;
|
|
37
|
+
const container = containerRef.current;
|
|
38
|
+
const indicator = indicatorRef.current;
|
|
39
|
+
if (!container || !indicator)
|
|
40
|
+
return;
|
|
41
|
+
if (currentValue === undefined) {
|
|
42
|
+
indicator.style.display = "none";
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
const activeButton = container.querySelector('button[aria-checked="true"]');
|
|
46
|
+
if (activeButton) {
|
|
47
|
+
// Prefer layout metrics relative to the container to avoid
|
|
48
|
+
// transform/zoom-related drift in viewport-based rect calculations.
|
|
49
|
+
let left = activeButton.offsetLeft;
|
|
50
|
+
let top = activeButton.offsetTop;
|
|
51
|
+
let width = activeButton.offsetWidth;
|
|
52
|
+
let height = activeButton.offsetHeight;
|
|
53
|
+
if (width === 0 || height === 0) {
|
|
54
|
+
const containerRect = container.getBoundingClientRect();
|
|
55
|
+
const buttonRect = activeButton.getBoundingClientRect();
|
|
56
|
+
left = buttonRect.left - containerRect.left;
|
|
57
|
+
top = buttonRect.top - containerRect.top;
|
|
58
|
+
width = buttonRect.width;
|
|
59
|
+
height = buttonRect.height;
|
|
60
|
+
}
|
|
61
|
+
const safeLeft = Math.max(0, left);
|
|
62
|
+
const safeTop = Math.max(0, top);
|
|
63
|
+
const containerWidth = container.clientWidth || container.offsetWidth;
|
|
64
|
+
const containerHeight = container.clientHeight || container.offsetHeight;
|
|
65
|
+
const hasContainerMetrics = containerWidth > 0 && containerHeight > 0;
|
|
66
|
+
const maxWidth = hasContainerMetrics
|
|
67
|
+
? Math.max(0, containerWidth - safeLeft)
|
|
68
|
+
: Number.POSITIVE_INFINITY;
|
|
69
|
+
const maxHeight = hasContainerMetrics
|
|
70
|
+
? Math.max(0, containerHeight - safeTop)
|
|
71
|
+
: Number.POSITIVE_INFINITY;
|
|
72
|
+
const safeWidth = Math.max(0, Math.min(width, maxWidth));
|
|
73
|
+
const safeHeight = Math.max(0, Math.min(height, maxHeight));
|
|
74
|
+
if (safeWidth === 0 || safeHeight === 0) {
|
|
75
|
+
indicator.style.display = "none";
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
indicator.style.left = `${safeLeft}px`;
|
|
79
|
+
indicator.style.top = `${safeTop}px`;
|
|
80
|
+
indicator.style.width = `${safeWidth}px`;
|
|
81
|
+
indicator.style.height = `${safeHeight}px`;
|
|
82
|
+
indicator.style.display = "block";
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
indicator.style.display = "none";
|
|
86
|
+
}
|
|
87
|
+
}, [animated, currentValue]);
|
|
88
|
+
react.useEffect(() => {
|
|
89
|
+
if (!animated)
|
|
90
|
+
return;
|
|
91
|
+
updateIndicator();
|
|
92
|
+
}, [animated, updateIndicator]);
|
|
93
|
+
react.useEffect(() => {
|
|
94
|
+
if (!animated)
|
|
95
|
+
return;
|
|
96
|
+
const container = containerRef.current;
|
|
97
|
+
if (!container)
|
|
98
|
+
return;
|
|
99
|
+
const observer = new ResizeObserver(() => {
|
|
100
|
+
updateIndicator();
|
|
101
|
+
});
|
|
102
|
+
observer.observe(container);
|
|
103
|
+
return () => observer.disconnect();
|
|
104
|
+
}, [animated, updateIndicator]);
|
|
105
|
+
react.useEffect(() => {
|
|
106
|
+
if (!animated || typeof window === "undefined")
|
|
107
|
+
return;
|
|
108
|
+
const handleWindowResize = () => {
|
|
109
|
+
updateIndicator();
|
|
110
|
+
};
|
|
111
|
+
window.addEventListener("resize", handleWindowResize);
|
|
112
|
+
return () => window.removeEventListener("resize", handleWindowResize);
|
|
113
|
+
}, [animated, updateIndicator]);
|
|
114
|
+
return (jsxRuntime.jsx(ToggleGroupContext.Provider, { value: {
|
|
115
|
+
value: currentValue,
|
|
116
|
+
defaultValue,
|
|
117
|
+
name: name ?? `togglegroup-name-${nameId}`,
|
|
118
|
+
onChange: onValueChange,
|
|
119
|
+
}, children: jsxRuntime.jsx(RovingFocusRoot.RovingFocusRoot, { asChild: true, activeValue: currentValue, orientation: "ambiguous", children: jsxRuntime.jsxs("div", { className: cl("ds-togglegroup", className), role: "radiogroup", ref: (node) => {
|
|
120
|
+
containerRef.current = node;
|
|
121
|
+
if (typeof ref === "function")
|
|
122
|
+
ref(node);
|
|
123
|
+
else if (ref)
|
|
124
|
+
ref.current = node;
|
|
125
|
+
}, ...rest, children: [animated && (jsxRuntime.jsx("div", { ref: indicatorRef, className: "ds-togglegroup__indicator", "aria-hidden": "true", style: { display: "none" } })), name && jsxRuntime.jsx("input", { type: "hidden", name: name, value: currentValue }), children] }) }) }));
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
exports.ToggleGroup = ToggleGroup;
|
|
129
|
+
exports.ToggleGroupContext = ToggleGroupContext;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var react = require('react');
|
|
6
|
+
var RovingFocusItem = require('../../utilities/RovingFocus/RovingFocusItem.js');
|
|
7
|
+
var Button = require('../Button/Button.js');
|
|
8
|
+
var useToggleGroupitem = require('./useToggleGroupitem.js');
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* A single item in a ToggleGroup.
|
|
12
|
+
* @example
|
|
13
|
+
* <ToggleGroup.Item value='1'>Toggle 1</ToggleGroup.Item>
|
|
14
|
+
*/
|
|
15
|
+
const ToggleGroupItem = react.forwardRef(function ToggleGroupItem(rest, ref) {
|
|
16
|
+
const { active, buttonProps, value } = useToggleGroupitem.useToggleGroupItem(rest);
|
|
17
|
+
return (jsxRuntime.jsx(RovingFocusItem.RovingFocusItem, { asChild: true, value: value, children: jsxRuntime.jsx(Button.Button, { variant: active ? 'primary' : 'tertiary', ref: ref, ...rest, ...buttonProps }) }));
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
exports.ToggleGroupItem = ToggleGroupItem;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var ToggleGroup$1 = require('./ToggleGroup.js');
|
|
5
|
+
var ToggleGroupItem = require('./ToggleGroupItem.js');
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Display a group of buttons that can be toggled between.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* <ToggleGroup onChange={(value) => console.log(value)}>
|
|
12
|
+
* <ToggleGroup.Item value='1'>Toggle 1</ToggleGroup.Item>
|
|
13
|
+
* <ToggleGroup.Item value='2'>Toggle 2</ToggleGroup.Item>
|
|
14
|
+
* <ToggleGroup.Item value='3'>Toggle 3</ToggleGroup.Item>
|
|
15
|
+
* </ToggleGroup>
|
|
16
|
+
*/
|
|
17
|
+
const ToggleGroup = Object.assign(ToggleGroup$1.ToggleGroup, {
|
|
18
|
+
Item: ToggleGroupItem.ToggleGroupItem,
|
|
19
|
+
});
|
|
20
|
+
ToggleGroup.Item.displayName = 'ToggleGroup.Item';
|
|
21
|
+
|
|
22
|
+
exports.ToggleGroupItem = ToggleGroupItem.ToggleGroupItem;
|
|
23
|
+
exports.ToggleGroup = ToggleGroup;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var react = require('react');
|
|
5
|
+
var ToggleGroup = require('./ToggleGroup.js');
|
|
6
|
+
|
|
7
|
+
/** Handles props for `ToggleGroup.Item` in context with `ToggleGroup` and `RovingFocus` */
|
|
8
|
+
const useToggleGroupItem = (props) => {
|
|
9
|
+
const { ...rest } = props;
|
|
10
|
+
const genValue = react.useId();
|
|
11
|
+
const toggleGroup = react.useContext(ToggleGroup.ToggleGroupContext);
|
|
12
|
+
const value = props.value ?? genValue;
|
|
13
|
+
const active = toggleGroup.value === value;
|
|
14
|
+
const buttonId = `togglegroup-item-${react.useId()}`;
|
|
15
|
+
return {
|
|
16
|
+
...rest,
|
|
17
|
+
active: active,
|
|
18
|
+
value,
|
|
19
|
+
buttonProps: {
|
|
20
|
+
id: buttonId,
|
|
21
|
+
'aria-checked': active,
|
|
22
|
+
'aria-current': active,
|
|
23
|
+
role: 'radio',
|
|
24
|
+
name: toggleGroup.name,
|
|
25
|
+
onClick: () => {
|
|
26
|
+
toggleGroup.onChange?.(value);
|
|
27
|
+
},
|
|
28
|
+
},
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
exports.useToggleGroupItem = useToggleGroupItem;
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var dom = require('@floating-ui/dom');
|
|
6
|
+
var reactSlot = require('@radix-ui/react-slot');
|
|
7
|
+
var cl = require('clsx/lite');
|
|
8
|
+
var react = require('react');
|
|
9
|
+
var react$1 = require('@floating-ui/react');
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Tooltip component that displays a small piece of information when hovering or focusing on an element.
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* <Tooltip content='This is a tooltip'>
|
|
16
|
+
* <button>Hover me</button>
|
|
17
|
+
* </Tooltip>
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* <Tooltip content='This is a tooltip'>
|
|
21
|
+
* Hover me
|
|
22
|
+
* </Tooltip>
|
|
23
|
+
*/
|
|
24
|
+
const Tooltip = react.forwardRef(function Tooltip({ id, children, content, placement = 'top', open, className, ...rest }, ref) {
|
|
25
|
+
const randomTooltipId = react.useId();
|
|
26
|
+
const [internalOpen, setInternalOpen] = react.useState(false);
|
|
27
|
+
const triggerRef = react.useRef(null);
|
|
28
|
+
const tooltipRef = react.useRef(null);
|
|
29
|
+
const mergedRefs = react$1.useMergeRefs([tooltipRef, ref]);
|
|
30
|
+
const controlledOpen = open ?? internalOpen;
|
|
31
|
+
const setOpen = () => {
|
|
32
|
+
setInternalOpen(true);
|
|
33
|
+
};
|
|
34
|
+
const setClose = () => {
|
|
35
|
+
setInternalOpen(false);
|
|
36
|
+
};
|
|
37
|
+
// Position with floating-ui
|
|
38
|
+
react.useEffect(() => {
|
|
39
|
+
const tooltip = tooltipRef.current;
|
|
40
|
+
const trigger = triggerRef.current;
|
|
41
|
+
tooltip?.togglePopover?.(controlledOpen);
|
|
42
|
+
if (tooltip)
|
|
43
|
+
tooltip.style.opacity = controlledOpen ? '1' : '0';
|
|
44
|
+
if (tooltip && trigger && controlledOpen) {
|
|
45
|
+
return dom.autoUpdate(trigger, tooltip, () => {
|
|
46
|
+
dom.computePosition(trigger, tooltip, {
|
|
47
|
+
placement,
|
|
48
|
+
strategy: 'fixed',
|
|
49
|
+
middleware: [
|
|
50
|
+
dom.offset((data) => {
|
|
51
|
+
// get pseudo element arrow size
|
|
52
|
+
const styles = getComputedStyle(data.elements.floating, '::before');
|
|
53
|
+
return parseFloat(styles.height);
|
|
54
|
+
}),
|
|
55
|
+
dom.flip({
|
|
56
|
+
fallbackAxisSideDirection: 'start',
|
|
57
|
+
}),
|
|
58
|
+
dom.shift(),
|
|
59
|
+
arrowPseudoElement,
|
|
60
|
+
],
|
|
61
|
+
}).then(({ x, y }) => {
|
|
62
|
+
tooltip.style.translate = `${x}px ${y}px`;
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
}, [controlledOpen, placement]);
|
|
67
|
+
/* Add listener for ESC to dismiss */
|
|
68
|
+
react.useEffect(() => {
|
|
69
|
+
const handleKeyDown = (event) => {
|
|
70
|
+
if (event.key === 'Escape') {
|
|
71
|
+
setInternalOpen(false);
|
|
72
|
+
}
|
|
73
|
+
};
|
|
74
|
+
window.addEventListener('keydown', handleKeyDown);
|
|
75
|
+
return () => {
|
|
76
|
+
window.removeEventListener('keydown', handleKeyDown);
|
|
77
|
+
};
|
|
78
|
+
}, []);
|
|
79
|
+
/* If children is only a string, make a span */
|
|
80
|
+
const ChildContainer = typeof children === 'string' ? 'span' : reactSlot.Slot;
|
|
81
|
+
/* Make sure it is valid */
|
|
82
|
+
if (typeof children !== 'string' && children.type === react.Fragment) {
|
|
83
|
+
console.error('<Tooltip> children needs to be a single ReactElement that can receive a ref and not: <Fragment/> | <></>');
|
|
84
|
+
return null;
|
|
85
|
+
}
|
|
86
|
+
const popoverProps = {
|
|
87
|
+
[react.version.startsWith('19') ? 'popoverTarget' : 'popovertarget']: id ?? randomTooltipId,
|
|
88
|
+
[react.version.startsWith('19')
|
|
89
|
+
? 'popoverTargetAction'
|
|
90
|
+
: 'popovertargetaction']: 'show',
|
|
91
|
+
};
|
|
92
|
+
return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(ChildContainer, { ref: triggerRef, ...popoverProps, onMouseEnter: setOpen, onMouseLeave: setClose, onFocus: setOpen, onBlur: setClose, children: children }), jsxRuntime.jsx("div", { ref: mergedRefs, role: 'tooltip', className: cl('ds-tooltip', className), id: id ?? randomTooltipId,
|
|
93
|
+
// @ts-ignore @types/react-dom does not understand popover yet
|
|
94
|
+
popover: 'manual', ...rest, children: content })] }));
|
|
95
|
+
});
|
|
96
|
+
const arrowPseudoElement = {
|
|
97
|
+
name: 'ArrowPseudoElement',
|
|
98
|
+
fn(data) {
|
|
99
|
+
const { elements, rects, placement } = data;
|
|
100
|
+
let arrowX = `${Math.round(rects.reference.width / 2 + rects.reference.x - data.x)}px`;
|
|
101
|
+
let arrowY = `${Math.round(rects.reference.height / 2 + rects.reference.y - data.y)}px`;
|
|
102
|
+
switch (placement) {
|
|
103
|
+
case 'top':
|
|
104
|
+
arrowY = '100%';
|
|
105
|
+
break;
|
|
106
|
+
case 'right':
|
|
107
|
+
arrowX = '0';
|
|
108
|
+
break;
|
|
109
|
+
case 'bottom':
|
|
110
|
+
arrowY = '0';
|
|
111
|
+
break;
|
|
112
|
+
case 'left':
|
|
113
|
+
arrowX = '100%';
|
|
114
|
+
break;
|
|
115
|
+
}
|
|
116
|
+
elements.floating.style.setProperty('--dsc-tooltip-arrow-x', arrowX);
|
|
117
|
+
elements.floating.style.setProperty('--dsc-tooltip-arrow-y', arrowY);
|
|
118
|
+
return data;
|
|
119
|
+
},
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
exports.Tooltip = Tooltip;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var reactSlot = require('@radix-ui/react-slot');
|
|
6
|
+
var cl = require('clsx/lite');
|
|
7
|
+
var react = require('react');
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Use `ValidationMessage` to display validation text
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* <ValidationMessage>This is a danger validation message</ValidationMessage>
|
|
14
|
+
*/
|
|
15
|
+
const ValidationMessage = react.forwardRef(function ValidationMessage({ className, asChild, ...rest }, ref) {
|
|
16
|
+
const Component = asChild ? reactSlot.Slot : 'p';
|
|
17
|
+
return (jsxRuntime.jsx(Component, { className: cl('ds-validation-message', className), "data-field": 'validation', ref: ref, ...rest }));
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
exports.ValidationMessage = ValidationMessage;
|