@digdir/designsystemet-react 1.0.0-next.47 → 1.0.0-next.49
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/cjs/components/Alert/Alert.js +2 -1
- package/dist/cjs/components/Badge/Badge.js +5 -9
- package/dist/cjs/components/Badge/BadgePosition.js +9 -0
- package/dist/cjs/components/Badge/index.js +6 -0
- package/dist/cjs/components/Breadcrumbs/Breadcrumbs.js +18 -0
- package/dist/cjs/components/Breadcrumbs/index.js +13 -8
- package/dist/cjs/components/Button/Button.js +2 -1
- package/dist/cjs/components/Card/Card.js +3 -2
- package/dist/cjs/components/Card/index.js +10 -0
- package/dist/cjs/components/Checkbox/Checkbox.js +3 -2
- package/dist/cjs/components/Chip/Chips.js +1 -0
- package/dist/cjs/components/Combobox/Combobox.js +5 -4
- package/dist/cjs/components/Combobox/Custom.js +1 -1
- package/dist/cjs/components/Combobox/index.js +3 -0
- package/dist/cjs/components/Combobox/internal/ComboboxChips.js +1 -1
- package/dist/cjs/components/Details/Details.js +5 -4
- package/dist/cjs/components/Details/DetailsContent.js +1 -0
- package/dist/cjs/components/Details/DetailsSummary.js +1 -0
- package/dist/cjs/components/Details/index.js +4 -3
- package/dist/cjs/components/Dialog/Dialog.js +74 -0
- package/dist/cjs/components/Dialog/DialogBlock.js +30 -0
- package/dist/cjs/components/Dialog/DialogTrigger.js +27 -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 +6 -0
- package/dist/cjs/components/Dropdown/Dropdown.js +27 -0
- package/dist/cjs/components/Dropdown/DropdownTriggerContext.js +4 -1
- package/dist/cjs/components/Dropdown/index.js +11 -9
- package/dist/cjs/components/ErrorSummary/ErrorSummary.js +20 -2
- package/dist/cjs/components/ErrorSummary/ErrorSummaryItem.js +10 -4
- package/dist/cjs/components/ErrorSummary/ErrorSummaryLink.js +15 -0
- package/dist/cjs/components/ErrorSummary/index.js +15 -4
- package/dist/cjs/components/Field/Field.js +11 -0
- package/dist/cjs/components/Field/FieldAffix.js +21 -0
- package/dist/cjs/components/Field/FieldCounter.js +9 -0
- package/dist/cjs/components/Field/index.js +7 -5
- package/dist/cjs/components/Fieldset/Fieldset.js +15 -0
- package/dist/cjs/components/Fieldset/FieldsetDescription.js +8 -0
- package/dist/cjs/components/Fieldset/FieldsetLegend.js +6 -0
- package/dist/cjs/components/Fieldset/index.js +10 -3
- package/dist/cjs/components/Input/Input.js +2 -3
- package/dist/cjs/components/Label/Label.js +2 -2
- package/dist/cjs/components/Link/Link.js +6 -0
- package/dist/cjs/components/List/Lists.js +20 -0
- package/dist/cjs/components/Pagination/Pagination.js +18 -0
- package/dist/cjs/components/Pagination/PaginationButton.js +8 -0
- package/dist/cjs/components/Pagination/PaginationItem.js +10 -0
- package/dist/cjs/components/Pagination/PaginationList.js +12 -0
- package/dist/cjs/components/Pagination/index.js +18 -0
- package/dist/cjs/components/Paragraph/Paragraph.js +1 -0
- package/dist/cjs/components/Popover/Popover.js +19 -2
- package/dist/cjs/components/Popover/PopoverTrigger.js +27 -2
- package/dist/cjs/components/Popover/PopoverTriggerContext.js +11 -0
- package/dist/cjs/components/Popover/index.js +15 -3
- package/dist/cjs/components/Radio/Radio.js +3 -2
- package/dist/cjs/components/Search/Search.js +16 -0
- package/dist/cjs/components/Search/SearchButton.js +9 -0
- package/dist/cjs/components/Search/SearchClear.js +9 -0
- package/dist/cjs/components/Search/SearchInput.js +8 -0
- package/dist/cjs/components/Search/index.js +11 -7
- package/dist/cjs/components/Select/Select.js +9 -0
- package/dist/cjs/components/Select/SelectOptgroup.js +11 -0
- package/dist/cjs/components/Select/SelectOption.js +9 -0
- package/dist/cjs/components/Select/index.js +9 -0
- package/dist/cjs/components/Skeleton/Skeleton.js +5 -4
- package/dist/cjs/components/SkipLink/SkipLink.js +7 -0
- package/dist/cjs/components/Spinner/Spinner.js +6 -1
- package/dist/cjs/components/Suggestion/Suggestion.js +55 -0
- package/dist/cjs/components/Suggestion/SuggestionClear.js +48 -0
- package/dist/cjs/components/Suggestion/SuggestionEmpty.js +23 -0
- package/dist/cjs/components/Suggestion/SuggestionInput.js +45 -0
- package/dist/cjs/components/Suggestion/SuggestionList.js +30 -0
- package/dist/cjs/components/Suggestion/SuggestionOption.js +12 -0
- package/dist/cjs/components/Suggestion/index.js +44 -0
- package/dist/cjs/components/Switch/Switch.js +1 -0
- package/dist/cjs/components/Table/Table.js +25 -0
- package/dist/cjs/components/Table/TableBody.js +11 -0
- package/dist/cjs/components/Table/TableCell.js +6 -0
- package/dist/cjs/components/Table/TableFoot.js +11 -0
- package/dist/cjs/components/Table/TableHead.js +11 -0
- package/dist/cjs/components/Table/TableHeaderCell.js +6 -0
- package/dist/cjs/components/Table/TableRow.js +9 -0
- package/dist/cjs/components/Table/index.js +25 -0
- package/dist/cjs/components/Tabs/Tabs.js +1 -2
- package/dist/cjs/components/Tabs/TabsList.js +1 -2
- package/dist/cjs/components/Tabs/TabsPanel.js +1 -2
- package/dist/cjs/components/Tabs/TabsTab.js +1 -0
- package/dist/cjs/components/Tabs/index.js +1 -2
- package/dist/cjs/components/Tag/Tag.js +3 -2
- package/dist/cjs/components/Textarea/Textarea.js +2 -3
- package/dist/cjs/components/Textfield/Textfield.js +1 -3
- package/dist/cjs/components/ToggleGroup/ToggleGroup.js +1 -0
- package/dist/cjs/components/ToggleGroup/index.js +4 -4
- package/dist/cjs/components/Tooltip/Tooltip.js +8 -4
- package/dist/cjs/components/ValidationMessage/ValidationMessage.js +6 -1
- package/dist/cjs/index.js +24 -12
- package/dist/cjs/utilities/RovingFocus/RovingFocusRoot.js +1 -1
- package/dist/cjs/{components/Pagination → utilities/hooks/usePagination}/usePagination.js +39 -2
- package/dist/esm/components/Alert/Alert.js +2 -1
- package/dist/esm/components/Badge/Badge.js +5 -9
- package/dist/esm/components/Badge/BadgePosition.js +9 -0
- package/dist/esm/components/Badge/index.js +6 -0
- package/dist/esm/components/Breadcrumbs/Breadcrumbs.js +18 -0
- package/dist/esm/components/Breadcrumbs/index.js +13 -8
- package/dist/esm/components/Button/Button.js +3 -2
- package/dist/esm/components/Card/Card.js +3 -2
- package/dist/esm/components/Card/index.js +10 -0
- package/dist/esm/components/Checkbox/Checkbox.js +3 -2
- package/dist/esm/components/Chip/Chips.js +2 -1
- package/dist/esm/components/Chip/index.js +1 -1
- package/dist/esm/components/Combobox/Combobox.js +6 -5
- package/dist/esm/components/Combobox/ComboboxIdContext.js +1 -1
- package/dist/esm/components/Combobox/Custom.js +1 -1
- package/dist/esm/components/Combobox/index.js +3 -0
- package/dist/esm/components/Combobox/internal/ComboboxChips.js +1 -1
- package/dist/esm/components/Combobox/useFloatingCombobox.js +1 -1
- package/dist/esm/components/Details/Details.js +5 -4
- package/dist/esm/components/Details/DetailsContent.js +1 -0
- package/dist/esm/components/Details/DetailsSummary.js +1 -0
- package/dist/esm/components/Details/index.js +4 -3
- package/dist/esm/components/Dialog/Dialog.js +72 -0
- package/dist/esm/components/Dialog/DialogBlock.js +28 -0
- package/dist/esm/components/{Modal/ModalTrigger.js → Dialog/DialogTrigger.js} +14 -3
- 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 +6 -0
- package/dist/esm/components/Dropdown/Dropdown.js +27 -0
- package/dist/esm/components/Dropdown/DropdownTriggerContext.js +4 -1
- package/dist/esm/components/Dropdown/index.js +11 -9
- package/dist/esm/components/ErrorSummary/ErrorSummary.js +21 -3
- package/dist/esm/components/ErrorSummary/ErrorSummaryItem.js +10 -4
- package/dist/esm/components/ErrorSummary/ErrorSummaryLink.js +13 -0
- package/dist/esm/components/ErrorSummary/index.js +15 -5
- package/dist/esm/components/Field/Field.js +11 -0
- package/dist/esm/components/Field/FieldAffix.js +21 -0
- package/dist/esm/components/Field/FieldCounter.js +9 -0
- package/dist/esm/components/Field/index.js +8 -6
- package/dist/esm/components/Fieldset/Fieldset.js +15 -0
- package/dist/esm/components/Fieldset/FieldsetDescription.js +8 -0
- package/dist/esm/components/Fieldset/FieldsetLegend.js +6 -0
- package/dist/esm/components/Fieldset/index.js +10 -3
- package/dist/esm/components/Input/Input.js +2 -3
- package/dist/esm/components/Label/Label.js +2 -2
- package/dist/esm/components/Link/Link.js +6 -0
- package/dist/esm/components/List/Lists.js +20 -0
- package/dist/esm/components/List/index.js +1 -1
- package/dist/esm/components/Pagination/Pagination.js +18 -0
- package/dist/esm/components/Pagination/PaginationButton.js +8 -0
- package/dist/esm/components/Pagination/PaginationItem.js +10 -0
- package/dist/esm/components/Pagination/PaginationList.js +12 -0
- package/dist/esm/components/Pagination/index.js +18 -0
- package/dist/esm/components/Paragraph/Paragraph.js +1 -0
- package/dist/esm/components/Popover/Popover.js +19 -2
- package/dist/esm/components/Popover/PopoverTrigger.js +28 -3
- package/dist/esm/components/Popover/PopoverTriggerContext.js +11 -0
- package/dist/esm/components/Popover/index.js +15 -3
- package/dist/esm/components/Radio/Radio.js +3 -2
- package/dist/esm/components/Search/Search.js +16 -0
- package/dist/esm/components/Search/SearchButton.js +9 -0
- package/dist/esm/components/Search/SearchClear.js +9 -0
- package/dist/esm/components/Search/SearchInput.js +8 -0
- package/dist/esm/components/Search/index.js +11 -7
- package/dist/esm/components/Select/Select.js +9 -0
- package/dist/esm/components/Select/SelectOptgroup.js +11 -0
- package/dist/esm/components/Select/SelectOption.js +9 -0
- package/dist/esm/components/Select/index.js +9 -0
- package/dist/esm/components/Skeleton/Skeleton.js +5 -4
- package/dist/esm/components/SkipLink/SkipLink.js +7 -0
- package/dist/esm/components/Spinner/Spinner.js +6 -1
- package/dist/esm/components/Suggestion/Suggestion.js +52 -0
- package/dist/esm/components/Suggestion/SuggestionClear.js +45 -0
- package/dist/esm/components/Suggestion/SuggestionEmpty.js +21 -0
- package/dist/esm/components/Suggestion/SuggestionInput.js +43 -0
- package/dist/esm/components/Suggestion/SuggestionList.js +28 -0
- package/dist/esm/components/Suggestion/SuggestionOption.js +10 -0
- package/dist/esm/components/Suggestion/index.js +37 -0
- package/dist/esm/components/Switch/Switch.js +1 -0
- package/dist/esm/components/Table/Table.js +25 -0
- package/dist/esm/components/Table/TableBody.js +11 -0
- package/dist/esm/components/Table/TableCell.js +6 -0
- package/dist/esm/components/Table/TableFoot.js +11 -0
- package/dist/esm/components/Table/TableHead.js +11 -0
- package/dist/esm/components/Table/TableHeaderCell.js +6 -0
- package/dist/esm/components/Table/TableRow.js +9 -0
- package/dist/esm/components/Table/index.js +25 -0
- package/dist/esm/components/Tabs/Tabs.js +2 -3
- package/dist/esm/components/Tabs/TabsList.js +1 -2
- package/dist/esm/components/Tabs/TabsPanel.js +1 -2
- package/dist/esm/components/Tabs/TabsTab.js +1 -0
- package/dist/esm/components/Tabs/index.js +1 -2
- package/dist/esm/components/Tag/Tag.js +3 -2
- package/dist/esm/components/Textarea/Textarea.js +2 -3
- package/dist/esm/components/Textfield/Textfield.js +1 -3
- package/dist/esm/components/ToggleGroup/ToggleGroup.js +2 -1
- package/dist/esm/components/ToggleGroup/index.js +4 -4
- package/dist/esm/components/Tooltip/Tooltip.js +9 -5
- package/dist/esm/components/ValidationMessage/ValidationMessage.js +6 -1
- package/dist/esm/index.js +12 -6
- package/dist/esm/utilities/RovingFocus/RovingFocusRoot.js +2 -2
- package/dist/esm/{components/Pagination → utilities/hooks/usePagination}/usePagination.js +39 -2
- package/dist/types/colors.d.ts +12 -2
- package/dist/types/colors.d.ts.map +1 -1
- package/dist/types/components/Alert/Alert.d.ts +6 -3
- package/dist/types/components/Alert/Alert.d.ts.map +1 -1
- package/dist/types/components/Alert/index.d.ts +2 -1
- package/dist/types/components/Alert/index.d.ts.map +1 -1
- package/dist/types/components/Badge/Badge.d.ts +16 -8
- package/dist/types/components/Badge/Badge.d.ts.map +1 -1
- package/dist/types/components/Badge/BadgePosition.d.ts +9 -0
- package/dist/types/components/Badge/BadgePosition.d.ts.map +1 -1
- package/dist/types/components/Badge/index.d.ts +8 -1
- package/dist/types/components/Badge/index.d.ts.map +1 -1
- package/dist/types/components/Breadcrumbs/Breadcrumbs.d.ts +18 -0
- package/dist/types/components/Breadcrumbs/Breadcrumbs.d.ts.map +1 -1
- package/dist/types/components/Breadcrumbs/BreadcrumbsLink.d.ts +1 -3
- package/dist/types/components/Breadcrumbs/BreadcrumbsLink.d.ts.map +1 -1
- package/dist/types/components/Breadcrumbs/index.d.ts +14 -11
- package/dist/types/components/Breadcrumbs/index.d.ts.map +1 -1
- package/dist/types/components/Button/Button.d.ts +19 -10
- package/dist/types/components/Button/Button.d.ts.map +1 -1
- package/dist/types/components/Card/Card.d.ts +18 -7
- package/dist/types/components/Card/Card.d.ts.map +1 -1
- package/dist/types/components/Card/index.d.ts +12 -2
- package/dist/types/components/Card/index.d.ts.map +1 -1
- package/dist/types/components/Checkbox/Checkbox.d.ts +17 -6
- package/dist/types/components/Checkbox/Checkbox.d.ts.map +1 -1
- package/dist/types/components/Checkbox/index.d.ts +2 -1
- package/dist/types/components/Checkbox/index.d.ts.map +1 -1
- package/dist/types/components/Chip/Chips.d.ts +1 -0
- package/dist/types/components/Chip/Chips.d.ts.map +1 -1
- package/dist/types/components/Combobox/Combobox.d.ts +3 -0
- package/dist/types/components/Combobox/Combobox.d.ts.map +1 -1
- package/dist/types/components/Combobox/ComboboxContext.d.ts +1 -1
- package/dist/types/components/Combobox/ComboboxContext.d.ts.map +1 -1
- package/dist/types/components/Combobox/Option/Option.d.ts +2 -2
- package/dist/types/components/Combobox/Option/Option.d.ts.map +1 -1
- package/dist/types/components/Combobox/Option/useComboboxOption.d.ts +6 -4
- package/dist/types/components/Combobox/Option/useComboboxOption.d.ts.map +1 -1
- package/dist/types/components/Combobox/index.d.ts +3 -0
- package/dist/types/components/Combobox/index.d.ts.map +1 -1
- package/dist/types/components/Combobox/useFloatingCombobox.d.ts +2 -2
- package/dist/types/components/Combobox/useFloatingCombobox.d.ts.map +1 -1
- package/dist/types/components/Details/Details.d.ts +13 -8
- package/dist/types/components/Details/Details.d.ts.map +1 -1
- package/dist/types/components/Details/DetailsContent.d.ts +1 -0
- package/dist/types/components/Details/DetailsContent.d.ts.map +1 -1
- package/dist/types/components/Details/DetailsSummary.d.ts +1 -0
- package/dist/types/components/Details/DetailsSummary.d.ts.map +1 -1
- package/dist/types/components/Details/index.d.ts +4 -3
- package/dist/types/components/Details/index.d.ts.map +1 -1
- package/dist/types/components/Dialog/Dialog.d.ts +69 -0
- package/dist/types/components/Dialog/Dialog.d.ts.map +1 -0
- package/dist/types/components/{Modal/ModalBlock.d.ts → Dialog/DialogBlock.d.ts} +19 -3
- package/dist/types/components/Dialog/DialogBlock.d.ts.map +1 -0
- package/dist/types/components/Dialog/DialogTrigger.d.ts +22 -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 +43 -0
- package/dist/types/components/Dialog/index.d.ts.map +1 -0
- package/dist/types/components/Divider/Divider.d.ts +6 -0
- package/dist/types/components/Divider/Divider.d.ts.map +1 -1
- package/dist/types/components/Dropdown/Dropdown.d.ts +31 -2
- package/dist/types/components/Dropdown/Dropdown.d.ts.map +1 -1
- package/dist/types/components/Dropdown/DropdownHeading.d.ts +1 -1
- package/dist/types/components/Dropdown/DropdownTriggerContext.d.ts +4 -1
- package/dist/types/components/Dropdown/DropdownTriggerContext.d.ts.map +1 -1
- package/dist/types/components/Dropdown/index.d.ts +12 -10
- package/dist/types/components/Dropdown/index.d.ts.map +1 -1
- package/dist/types/components/ErrorSummary/ErrorSummary.d.ts +22 -2
- package/dist/types/components/ErrorSummary/ErrorSummary.d.ts.map +1 -1
- package/dist/types/components/ErrorSummary/ErrorSummaryHeading.d.ts +1 -1
- package/dist/types/components/ErrorSummary/ErrorSummaryItem.d.ts +11 -21
- package/dist/types/components/ErrorSummary/ErrorSummaryItem.d.ts.map +1 -1
- 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/index.d.ts +25 -8
- package/dist/types/components/ErrorSummary/index.d.ts.map +1 -1
- package/dist/types/components/Field/Field.d.ts +15 -2
- package/dist/types/components/Field/Field.d.ts.map +1 -1
- package/dist/types/components/Field/FieldAffix.d.ts +21 -0
- package/dist/types/components/Field/FieldAffix.d.ts.map +1 -1
- package/dist/types/components/Field/FieldCounter.d.ts +35 -6
- package/dist/types/components/Field/FieldCounter.d.ts.map +1 -1
- package/dist/types/components/Field/index.d.ts +7 -5
- package/dist/types/components/Field/index.d.ts.map +1 -1
- package/dist/types/components/Fieldset/Fieldset.d.ts +15 -0
- package/dist/types/components/Fieldset/Fieldset.d.ts.map +1 -1
- package/dist/types/components/Fieldset/FieldsetDescription.d.ts +9 -1
- package/dist/types/components/Fieldset/FieldsetDescription.d.ts.map +1 -1
- package/dist/types/components/Fieldset/FieldsetLegend.d.ts +6 -0
- package/dist/types/components/Fieldset/FieldsetLegend.d.ts.map +1 -1
- package/dist/types/components/Fieldset/index.d.ts +11 -4
- package/dist/types/components/Fieldset/index.d.ts.map +1 -1
- package/dist/types/components/Heading/Heading.d.ts +8 -4
- package/dist/types/components/Heading/Heading.d.ts.map +1 -1
- package/dist/types/components/Heading/index.d.ts +2 -1
- package/dist/types/components/Heading/index.d.ts.map +1 -1
- package/dist/types/components/Input/Input.d.ts +22 -11
- package/dist/types/components/Input/Input.d.ts.map +1 -1
- package/dist/types/components/Label/Label.d.ts +2 -2
- package/dist/types/components/Label/index.d.ts +2 -1
- package/dist/types/components/Label/index.d.ts.map +1 -1
- package/dist/types/components/Link/Link.d.ts +13 -11
- package/dist/types/components/Link/Link.d.ts.map +1 -1
- package/dist/types/components/List/Lists.d.ts +20 -0
- package/dist/types/components/List/Lists.d.ts.map +1 -1
- package/dist/types/components/Pagination/Pagination.d.ts +18 -0
- package/dist/types/components/Pagination/Pagination.d.ts.map +1 -1
- package/dist/types/components/Pagination/PaginationButton.d.ts +8 -0
- package/dist/types/components/Pagination/PaginationButton.d.ts.map +1 -1
- package/dist/types/components/Pagination/PaginationItem.d.ts +10 -0
- package/dist/types/components/Pagination/PaginationItem.d.ts.map +1 -1
- package/dist/types/components/Pagination/PaginationList.d.ts +12 -0
- package/dist/types/components/Pagination/PaginationList.d.ts.map +1 -1
- package/dist/types/components/Pagination/index.d.ts +18 -2
- package/dist/types/components/Pagination/index.d.ts.map +1 -1
- package/dist/types/components/Paragraph/Paragraph.d.ts +3 -2
- package/dist/types/components/Paragraph/Paragraph.d.ts.map +1 -1
- package/dist/types/components/Paragraph/index.d.ts +2 -1
- package/dist/types/components/Paragraph/index.d.ts.map +1 -1
- package/dist/types/components/Popover/Popover.d.ts +46 -9
- package/dist/types/components/Popover/Popover.d.ts.map +1 -1
- package/dist/types/components/Popover/PopoverTrigger.d.ts +33 -0
- package/dist/types/components/Popover/PopoverTrigger.d.ts.map +1 -1
- package/dist/types/components/Popover/PopoverTriggerContext.d.ts +11 -0
- package/dist/types/components/Popover/PopoverTriggerContext.d.ts.map +1 -1
- package/dist/types/components/Popover/index.d.ts +26 -5
- package/dist/types/components/Popover/index.d.ts.map +1 -1
- package/dist/types/components/Radio/Radio.d.ts +17 -6
- package/dist/types/components/Radio/Radio.d.ts.map +1 -1
- package/dist/types/components/Radio/index.d.ts +2 -1
- package/dist/types/components/Radio/index.d.ts.map +1 -1
- package/dist/types/components/Search/Search.d.ts +16 -0
- package/dist/types/components/Search/Search.d.ts.map +1 -1
- package/dist/types/components/Search/SearchButton.d.ts +17 -3
- package/dist/types/components/Search/SearchButton.d.ts.map +1 -1
- package/dist/types/components/Search/SearchClear.d.ts +9 -0
- package/dist/types/components/Search/SearchClear.d.ts.map +1 -1
- package/dist/types/components/Search/SearchInput.d.ts +8 -0
- package/dist/types/components/Search/SearchInput.d.ts.map +1 -1
- package/dist/types/components/Search/index.d.ts +13 -9
- package/dist/types/components/Search/index.d.ts.map +1 -1
- package/dist/types/components/Select/Select.d.ts +17 -4
- package/dist/types/components/Select/Select.d.ts.map +1 -1
- package/dist/types/components/Select/SelectOptgroup.d.ts +11 -0
- package/dist/types/components/Select/SelectOptgroup.d.ts.map +1 -1
- package/dist/types/components/Select/SelectOption.d.ts +9 -0
- package/dist/types/components/Select/SelectOption.d.ts.map +1 -1
- package/dist/types/components/Select/index.d.ts +9 -0
- package/dist/types/components/Select/index.d.ts.map +1 -1
- package/dist/types/components/Skeleton/Skeleton.d.ts +15 -10
- package/dist/types/components/Skeleton/Skeleton.d.ts.map +1 -1
- package/dist/types/components/SkipLink/SkipLink.d.ts +19 -4
- package/dist/types/components/SkipLink/SkipLink.d.ts.map +1 -1
- package/dist/types/components/Spinner/Spinner.d.ts +10 -3
- package/dist/types/components/Spinner/Spinner.d.ts.map +1 -1
- package/dist/types/components/Spinner/index.d.ts +2 -1
- package/dist/types/components/Spinner/index.d.ts.map +1 -1
- package/dist/types/components/Suggestion/Suggestion.d.ts +102 -0
- package/dist/types/components/Suggestion/Suggestion.d.ts.map +1 -0
- package/dist/types/components/Suggestion/SuggestionClear.d.ts +35 -0
- package/dist/types/components/Suggestion/SuggestionClear.d.ts.map +1 -0
- package/dist/types/components/Suggestion/SuggestionEmpty.d.ts +28 -0
- package/dist/types/components/Suggestion/SuggestionEmpty.d.ts.map +1 -0
- package/dist/types/components/Suggestion/SuggestionInput.d.ts +21 -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 +6 -0
- package/dist/types/components/Suggestion/SuggestionOption.d.ts.map +1 -0
- package/dist/types/components/Suggestion/index.d.ts +56 -0
- package/dist/types/components/Suggestion/index.d.ts.map +1 -0
- package/dist/types/components/Switch/Switch.d.ts +15 -5
- package/dist/types/components/Switch/Switch.d.ts.map +1 -1
- package/dist/types/components/Switch/index.d.ts +2 -1
- package/dist/types/components/Switch/index.d.ts.map +1 -1
- package/dist/types/components/Table/Table.d.ts +33 -8
- package/dist/types/components/Table/Table.d.ts.map +1 -1
- package/dist/types/components/Table/TableBody.d.ts +11 -0
- package/dist/types/components/Table/TableBody.d.ts.map +1 -1
- package/dist/types/components/Table/TableCell.d.ts +6 -0
- package/dist/types/components/Table/TableCell.d.ts.map +1 -1
- package/dist/types/components/Table/TableFoot.d.ts +11 -0
- package/dist/types/components/Table/TableFoot.d.ts.map +1 -1
- package/dist/types/components/Table/TableHead.d.ts +11 -0
- package/dist/types/components/Table/TableHead.d.ts.map +1 -1
- package/dist/types/components/Table/TableHeaderCell.d.ts +6 -0
- package/dist/types/components/Table/TableHeaderCell.d.ts.map +1 -1
- package/dist/types/components/Table/TableRow.d.ts +9 -0
- package/dist/types/components/Table/TableRow.d.ts.map +1 -1
- package/dist/types/components/Table/index.d.ts +25 -0
- package/dist/types/components/Table/index.d.ts.map +1 -1
- package/dist/types/components/Tabs/Tabs.d.ts +25 -8
- package/dist/types/components/Tabs/Tabs.d.ts.map +1 -1
- package/dist/types/components/Tabs/TabsList.d.ts +1 -2
- package/dist/types/components/Tabs/TabsList.d.ts.map +1 -1
- package/dist/types/components/Tabs/TabsPanel.d.ts +9 -4
- package/dist/types/components/Tabs/TabsPanel.d.ts.map +1 -1
- package/dist/types/components/Tabs/TabsTab.d.ts +7 -2
- package/dist/types/components/Tabs/TabsTab.d.ts.map +1 -1
- package/dist/types/components/Tabs/index.d.ts +1 -2
- package/dist/types/components/Tabs/index.d.ts.map +1 -1
- package/dist/types/components/Tag/Tag.d.ts +3 -2
- package/dist/types/components/Tag/Tag.d.ts.map +1 -1
- package/dist/types/components/Tag/index.d.ts +2 -1
- package/dist/types/components/Tag/index.d.ts.map +1 -1
- package/dist/types/components/Textarea/Textarea.d.ts +2 -3
- package/dist/types/components/Textarea/Textarea.d.ts.map +1 -1
- package/dist/types/components/Textarea/index.d.ts +2 -1
- package/dist/types/components/Textarea/index.d.ts.map +1 -1
- package/dist/types/components/Textfield/Textfield.d.ts +30 -12
- package/dist/types/components/Textfield/Textfield.d.ts.map +1 -1
- package/dist/types/components/Textfield/index.d.ts +2 -1
- package/dist/types/components/Textfield/index.d.ts.map +1 -1
- package/dist/types/components/ToggleGroup/ToggleGroup.d.ts +25 -8
- package/dist/types/components/ToggleGroup/ToggleGroup.d.ts.map +1 -1
- package/dist/types/components/ToggleGroup/index.d.ts +13 -9
- package/dist/types/components/ToggleGroup/index.d.ts.map +1 -1
- package/dist/types/components/Tooltip/Tooltip.d.ts +8 -3
- package/dist/types/components/Tooltip/Tooltip.d.ts.map +1 -1
- package/dist/types/components/ValidationMessage/ValidationMessage.d.ts +6 -1
- package/dist/types/components/ValidationMessage/ValidationMessage.d.ts.map +1 -1
- package/dist/types/components/ValidationMessage/index.d.ts +2 -1
- package/dist/types/components/ValidationMessage/index.d.ts.map +1 -1
- package/dist/types/components/index.d.ts +2 -1
- package/dist/types/components/index.d.ts.map +1 -1
- package/dist/types/types.d.ts +2 -2
- package/dist/types/types.d.ts.map +1 -1
- package/dist/types/utilities/RovingFocus/useRovingFocus.d.ts +14 -1
- package/dist/types/utilities/RovingFocus/useRovingFocus.d.ts.map +1 -1
- package/dist/types/utilities/hooks/index.d.ts +2 -1
- package/dist/types/utilities/hooks/index.d.ts.map +1 -1
- package/dist/types/utilities/hooks/useCheckboxGroup/useCheckboxGroup.d.ts +7 -325
- package/dist/types/utilities/hooks/useCheckboxGroup/useCheckboxGroup.d.ts.map +1 -1
- package/dist/types/{components/Pagination → utilities/hooks/usePagination}/usePagination.d.ts +48 -12
- package/dist/types/utilities/hooks/usePagination/usePagination.d.ts.map +1 -0
- package/dist/types/utilities/hooks/useRadioGroup/useRadioGroup.d.ts +13 -327
- package/dist/types/utilities/hooks/useRadioGroup/useRadioGroup.d.ts.map +1 -1
- package/dist/types/utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.d.ts +1 -1
- package/dist/types/utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.d.ts.map +1 -1
- package/package.json +17 -14
- package/dist/cjs/components/Modal/Modal.js +0 -51
- package/dist/cjs/components/Modal/ModalBlock.js +0 -14
- package/dist/cjs/components/Modal/ModalTrigger.js +0 -16
- package/dist/cjs/components/Modal/ModalTriggerContext.js +0 -17
- package/dist/cjs/components/Modal/index.js +0 -21
- package/dist/cjs/utilities/hooks/usePrevious/usePrevious.js +0 -14
- package/dist/esm/components/Modal/Modal.js +0 -49
- package/dist/esm/components/Modal/ModalBlock.js +0 -12
- package/dist/esm/components/Modal/ModalTriggerContext.js +0 -14
- package/dist/esm/components/Modal/index.js +0 -16
- package/dist/esm/utilities/hooks/usePrevious/usePrevious.js +0 -12
- package/dist/types/components/Modal/Modal.d.ts +0 -38
- package/dist/types/components/Modal/Modal.d.ts.map +0 -1
- package/dist/types/components/Modal/ModalBlock.d.ts.map +0 -1
- package/dist/types/components/Modal/ModalTrigger.d.ts +0 -13
- package/dist/types/components/Modal/ModalTrigger.d.ts.map +0 -1
- package/dist/types/components/Modal/ModalTriggerContext.d.ts +0 -10
- package/dist/types/components/Modal/ModalTriggerContext.d.ts.map +0 -1
- package/dist/types/components/Modal/index.d.ts +0 -32
- package/dist/types/components/Modal/index.d.ts.map +0 -1
- package/dist/types/components/Pagination/usePagination.d.ts.map +0 -1
- package/dist/types/utilities/hooks/usePrevious/usePrevious.d.ts +0 -2
- package/dist/types/utilities/hooks/usePrevious/usePrevious.d.ts.map +0 -1
|
@@ -5,7 +5,12 @@ import cl from 'clsx/lite';
|
|
|
5
5
|
import { forwardRef } from 'react';
|
|
6
6
|
import { useSynchronizedAnimation } from '../../utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.js';
|
|
7
7
|
|
|
8
|
-
/**
|
|
8
|
+
/**
|
|
9
|
+
* Spinner component used for indicating busy or indeterminate loading.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* <Spinner aria-label='Loading users...' />
|
|
13
|
+
*/
|
|
9
14
|
const Spinner = forwardRef(function Spinner({ 'aria-label': ariaLabel, className, ...rest }, ref) {
|
|
10
15
|
const svgRef = useSynchronizedAnimation('ds-spinner-rotate-animation');
|
|
11
16
|
const strokeRef = useSynchronizedAnimation('ds-spinner-stroke-animation');
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
4
|
+
import { getDatalistValue, syncDatalistState } from '@u-elements/u-datalist';
|
|
5
|
+
import cl from 'clsx/lite';
|
|
6
|
+
import { forwardRef, createContext, useState, useId, useRef, useCallback } from 'react';
|
|
7
|
+
|
|
8
|
+
const SuggestionContext = createContext({});
|
|
9
|
+
/**
|
|
10
|
+
* A component that provides a suggestion list for an input field.
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* <Suggestion>
|
|
14
|
+
* <Suggestion.Input />
|
|
15
|
+
* <Suggestion.Clear />
|
|
16
|
+
* <Suggestion.List>
|
|
17
|
+
* <Suggestion.Empty>Tomt</Suggestion.Empty>
|
|
18
|
+
* <Suggestion.Option value='Option 1'>Option 1</Suggestion.Option>
|
|
19
|
+
* <Suggestion.Option value='Option 2'>Option 2</Suggestion.Option>
|
|
20
|
+
* </Suggestion.List>
|
|
21
|
+
* </Suggestion>
|
|
22
|
+
*/
|
|
23
|
+
const Suggestion = forwardRef(function Suggestion({ className, filter = true, asChild, ...rest }, ref) {
|
|
24
|
+
const Component = asChild ? Slot : 'div';
|
|
25
|
+
const [listId, setListId] = useState(useId());
|
|
26
|
+
const inputRef = useRef(null);
|
|
27
|
+
const handleFilter = useCallback((input) => {
|
|
28
|
+
const list = input?.list;
|
|
29
|
+
// Let <datalist> handle filtering if filter is true
|
|
30
|
+
if (filter === true || !list)
|
|
31
|
+
return;
|
|
32
|
+
// Handle custom filter
|
|
33
|
+
if (filter !== false) {
|
|
34
|
+
let index = 0;
|
|
35
|
+
for (const option of list.children) {
|
|
36
|
+
// Skip <datalist> children that are not <option>
|
|
37
|
+
if ('value' in option)
|
|
38
|
+
option.disabled = !filter({
|
|
39
|
+
index: index++, // Increment index for each <option>
|
|
40
|
+
input,
|
|
41
|
+
optionElement: option,
|
|
42
|
+
text: option.text,
|
|
43
|
+
value: getDatalistValue(option),
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
syncDatalistState(input); // Sync the datalist state if filter is custom or false
|
|
48
|
+
}, [filter]);
|
|
49
|
+
return (jsx(SuggestionContext.Provider, { value: { inputRef, listId, setListId, handleFilter }, children: jsx(Component, { className: cl('ds-suggestion', className), ref: ref, ...rest }) }));
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
export { Suggestion, SuggestionContext };
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { forwardRef, useContext } from 'react';
|
|
4
|
+
import { SuggestionContext } from './Suggestion.js';
|
|
5
|
+
import { Button } from '../Button/Button.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Component that provides a clear button for the suggestion input.
|
|
9
|
+
*
|
|
10
|
+
* Place as a descendant of `Suggestion`
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* <Suggestion>
|
|
14
|
+
* <Suggestion.Input />
|
|
15
|
+
* <Suggestion.Clear />
|
|
16
|
+
* <Suggestion.List />
|
|
17
|
+
* </Suggestion>
|
|
18
|
+
*/
|
|
19
|
+
const SuggestionClear = forwardRef(function SuggestionClear({ 'aria-label': label = 'Tøm', onClick, ...rest }, ref) {
|
|
20
|
+
const { inputRef } = useContext(SuggestionContext); //, handleValueChange
|
|
21
|
+
const handleClear = (event) => {
|
|
22
|
+
if (!inputRef?.current)
|
|
23
|
+
throw new Error('Input is missing');
|
|
24
|
+
/* narrow type to make TS happy */
|
|
25
|
+
if (!(inputRef?.current instanceof HTMLInputElement))
|
|
26
|
+
throw new Error('Input is not an input element');
|
|
27
|
+
event.preventDefault();
|
|
28
|
+
setReactInputValue(inputRef.current, '');
|
|
29
|
+
inputRef.current.focus();
|
|
30
|
+
onClick?.(event);
|
|
31
|
+
};
|
|
32
|
+
return (jsx(Button, { ref: ref, variant: 'tertiary', type: 'reset', "aria-label": label, onClick: handleClear, icon: true, ...rest }));
|
|
33
|
+
});
|
|
34
|
+
const setReactInputValue = (input, value) => {
|
|
35
|
+
const previousValue = input.value;
|
|
36
|
+
input.value = value;
|
|
37
|
+
const tracker = input._valueTracker;
|
|
38
|
+
if (typeof tracker !== 'undefined') {
|
|
39
|
+
tracker.setValue(previousValue);
|
|
40
|
+
}
|
|
41
|
+
//'change' instead of 'input', see https://github.com/facebook/react/issues/11488#issuecomment-381590324
|
|
42
|
+
input.dispatchEvent(new Event('change', { bubbles: true }));
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
export { SuggestionClear, setReactInputValue };
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
4
|
+
import { forwardRef } from 'react';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Component that provides an empty suggestion list.
|
|
8
|
+
*
|
|
9
|
+
* Place as a descendant of `Suggestion.List`
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* <Suggestion.List>
|
|
13
|
+
* <Suggestion.Empty>Tomt</Suggestion.Empty>
|
|
14
|
+
* </Suggestion.List>
|
|
15
|
+
*/
|
|
16
|
+
const SuggestionEmpty = forwardRef(function SuggestionEmpty({ asChild, ...rest }, ref) {
|
|
17
|
+
const Component = asChild ? Slot : 'div';
|
|
18
|
+
return (jsx(Component, { "aria-disabled": 'true', ref: ref, role: 'option', tabIndex: 0, ...rest }));
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
export { SuggestionEmpty };
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { useMergeRefs } from '@floating-ui/react';
|
|
4
|
+
import { getDatalistValue, isDatalistClick } from '@u-elements/u-datalist';
|
|
5
|
+
import { forwardRef, useContext, useCallback, useEffect } from 'react';
|
|
6
|
+
import { SuggestionContext } from './Suggestion.js';
|
|
7
|
+
import { Input } from '../Input/Input.js';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Component that provides an input field for the suggestion list.
|
|
11
|
+
*
|
|
12
|
+
* Place as a descendant of `Suggestion`
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* <Suggestion>
|
|
16
|
+
* <Suggestion.Input />
|
|
17
|
+
* <Suggestion.List />
|
|
18
|
+
* </Suggestion>
|
|
19
|
+
*/
|
|
20
|
+
const SuggestionInput = forwardRef(function SuggestionList({ value, onInput, ...rest }, ref) {
|
|
21
|
+
const { listId, inputRef, handleFilter } = useContext(SuggestionContext);
|
|
22
|
+
const mergedRefs = useMergeRefs([inputRef, ref]);
|
|
23
|
+
const updateSelected = useCallback(() => {
|
|
24
|
+
const { list, value } = inputRef?.current || {};
|
|
25
|
+
for (const option of list?.options || []) {
|
|
26
|
+
option.selected = getDatalistValue(option) === value;
|
|
27
|
+
}
|
|
28
|
+
}, []);
|
|
29
|
+
// Update also if controlled value
|
|
30
|
+
useEffect(() => {
|
|
31
|
+
updateSelected();
|
|
32
|
+
handleFilter?.(inputRef?.current);
|
|
33
|
+
}, [value]);
|
|
34
|
+
return (jsx(Input, { ref: mergedRefs, list: listId, value: value, onInput: (event) => {
|
|
35
|
+
onInput?.(event); // Should run first
|
|
36
|
+
updateSelected();
|
|
37
|
+
if (!isDatalistClick(event.nativeEvent))
|
|
38
|
+
handleFilter?.(inputRef?.current);
|
|
39
|
+
}, placeholder: '' // We need an empty placeholder for the clear button to be able to show/hide
|
|
40
|
+
, ...rest }));
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
export { SuggestionInput };
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { forwardRef, useContext, useEffect } from 'react';
|
|
4
|
+
import '@u-elements/u-datalist';
|
|
5
|
+
import { SuggestionContext } from './Suggestion.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Component that provides a suggestion list.
|
|
9
|
+
*
|
|
10
|
+
* Place as a descendant of `Suggestion`
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* <Suggestion>
|
|
14
|
+
* <Suggestion.Input />
|
|
15
|
+
* <Suggestion.List />
|
|
16
|
+
* </Suggestion>
|
|
17
|
+
*/
|
|
18
|
+
const SuggestionList = forwardRef(function SuggestionList({ singular = '%d forslag', plural = '%d forslag', className, id, ...rest }, ref) {
|
|
19
|
+
const { inputRef, listId, setListId, handleFilter } = useContext(SuggestionContext);
|
|
20
|
+
useEffect(() => handleFilter?.(inputRef?.current)); // Must run on every render
|
|
21
|
+
useEffect(() => {
|
|
22
|
+
if (id && listId !== id)
|
|
23
|
+
setListId?.(id);
|
|
24
|
+
}, [listId, id, setListId]);
|
|
25
|
+
return (jsx("u-datalist", { "data-sr-singular": singular, "data-sr-plural": plural, class: className, id: listId, ref: ref, ...rest }));
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
export { SuggestionList };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import '@u-elements/u-datalist';
|
|
5
|
+
|
|
6
|
+
const SuggestionOption = forwardRef(function SuggestionOption({ className, ...rest }, ref) {
|
|
7
|
+
return (jsx("u-option", { class: className, ref: ref, ...rest }));
|
|
8
|
+
});
|
|
9
|
+
|
|
10
|
+
export { SuggestionOption };
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { Suggestion } from './Suggestion.js';
|
|
3
|
+
import { SuggestionClear } from './SuggestionClear.js';
|
|
4
|
+
import { SuggestionEmpty } from './SuggestionEmpty.js';
|
|
5
|
+
import { SuggestionInput } from './SuggestionInput.js';
|
|
6
|
+
import { SuggestionList } from './SuggestionList.js';
|
|
7
|
+
import { SuggestionOption } from './SuggestionOption.js';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* A component that provides a suggestion list for an input field.
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* <Suggestion>
|
|
14
|
+
* <Suggestion.Input />
|
|
15
|
+
* <Suggestion.Clear />
|
|
16
|
+
* <Suggestion.List>
|
|
17
|
+
* <Suggestion.Empty>Tomt</Suggestion.Empty>
|
|
18
|
+
* <Suggestion.Option value='Option 1'>Option 1</Suggestion.Option>
|
|
19
|
+
* <Suggestion.Option value='Option 2'>Option 2</Suggestion.Option>
|
|
20
|
+
* </Suggestion.List>
|
|
21
|
+
* </Suggestion>
|
|
22
|
+
*/
|
|
23
|
+
const EXPERIMENTAL_Suggestion = Object.assign(Suggestion, {
|
|
24
|
+
List: SuggestionList,
|
|
25
|
+
Input: SuggestionInput,
|
|
26
|
+
Empty: SuggestionEmpty,
|
|
27
|
+
Option: SuggestionOption,
|
|
28
|
+
Clear: SuggestionClear,
|
|
29
|
+
});
|
|
30
|
+
EXPERIMENTAL_Suggestion.displayName = 'EXPERIMENTAL_Suggestion';
|
|
31
|
+
EXPERIMENTAL_Suggestion.List.displayName = 'EXPERIMENTAL_Suggestion.List';
|
|
32
|
+
EXPERIMENTAL_Suggestion.Input.displayName = 'EXPERIMENTAL_Suggestion.Input';
|
|
33
|
+
EXPERIMENTAL_Suggestion.Empty.displayName = 'EXPERIMENTAL_Suggestion.Empty';
|
|
34
|
+
EXPERIMENTAL_Suggestion.Option.displayName = 'EXPERIMENTAL_Suggestion.Option';
|
|
35
|
+
EXPERIMENTAL_Suggestion.Clear.displayName = 'EXPERIMENTAL_Suggestion.Clear';
|
|
36
|
+
|
|
37
|
+
export { EXPERIMENTAL_Suggestion, SuggestionClear as EXPERIMENTAL_SuggestionClear, SuggestionEmpty as EXPERIMENTAL_SuggestionEmpty, SuggestionInput as EXPERIMENTAL_SuggestionInput, SuggestionList as EXPERIMENTAL_SuggestionList, SuggestionOption as EXPERIMENTAL_SuggestionOption };
|
|
@@ -3,6 +3,31 @@ import { jsx } from 'react/jsx-runtime';
|
|
|
3
3
|
import cl from 'clsx/lite';
|
|
4
4
|
import { forwardRef } from 'react';
|
|
5
5
|
|
|
6
|
+
/**
|
|
7
|
+
* Table component, used to display tabular data. Renders a native HTML table element.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* <Table>
|
|
11
|
+
* <Table.Head>
|
|
12
|
+
* <Table.Row>
|
|
13
|
+
* <Table.HeaderCell>Name</Table.HeaderCell>
|
|
14
|
+
* <Table.HeaderCell>Age</Table.HeaderCell>
|
|
15
|
+
* </Table.Row>
|
|
16
|
+
* </Table.Head>
|
|
17
|
+
* <Table.Body>
|
|
18
|
+
* <Table.Row>
|
|
19
|
+
* <Table.Cell>John</Table.Cell>
|
|
20
|
+
* <Table.Cell>25</Table.Cell>
|
|
21
|
+
* </Table.Row>
|
|
22
|
+
* </Table.Body>
|
|
23
|
+
* <Table.Foot>
|
|
24
|
+
* <Table.Row>
|
|
25
|
+
* <Table.Cell>Total</Table.Cell>
|
|
26
|
+
* <Table.Cell>2</Table.Cell>
|
|
27
|
+
* </Table.Row>
|
|
28
|
+
* </Table.Foot>
|
|
29
|
+
* </Table>
|
|
30
|
+
*/
|
|
6
31
|
const Table = forwardRef(function Table({ zebra = false, stickyHeader = false, border = false, hover = false, className, children, ...rest }, ref) {
|
|
7
32
|
return (jsx("table", { className: cl('ds-table', className), "data-border": border || undefined, "data-hover": hover || undefined, "data-sticky-header": stickyHeader || undefined, "data-zebra": zebra || undefined, ref: ref, ...rest, children: children }));
|
|
8
33
|
});
|
|
@@ -2,6 +2,17 @@
|
|
|
2
2
|
import { jsx } from 'react/jsx-runtime';
|
|
3
3
|
import { forwardRef } from 'react';
|
|
4
4
|
|
|
5
|
+
/**
|
|
6
|
+
* TableBody component, used to display the body of a table. Renders a native HTML tbody element.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* <Table.Body>
|
|
10
|
+
* <Table.Row>
|
|
11
|
+
* <Table.Cell>John</Table.Cell>
|
|
12
|
+
* <Table.Cell>25</Table.Cell>
|
|
13
|
+
* </Table.Row>
|
|
14
|
+
* </Table.Body>
|
|
15
|
+
*/
|
|
5
16
|
const TableBody = forwardRef(function TableBody(rest, ref) {
|
|
6
17
|
return jsx("tbody", { ref: ref, ...rest });
|
|
7
18
|
});
|
|
@@ -2,6 +2,12 @@
|
|
|
2
2
|
import { jsx } from 'react/jsx-runtime';
|
|
3
3
|
import { forwardRef } from 'react';
|
|
4
4
|
|
|
5
|
+
/**
|
|
6
|
+
* TableCell component, used to display the cells of a table. Renders a native HTML td element.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* <Table.Cell>John</Table.Cell>
|
|
10
|
+
*/
|
|
5
11
|
const TableCell = forwardRef(function TableCell(rest, ref) {
|
|
6
12
|
return jsx("td", { ref: ref, ...rest });
|
|
7
13
|
});
|
|
@@ -2,6 +2,17 @@
|
|
|
2
2
|
import { jsx } from 'react/jsx-runtime';
|
|
3
3
|
import { forwardRef } from 'react';
|
|
4
4
|
|
|
5
|
+
/**
|
|
6
|
+
* TableFoot component, used to display the footer of a table. Renders a native HTML tfoot element.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* <Table.Foot>
|
|
10
|
+
* <Table.Row>
|
|
11
|
+
* <Table.Cell>Total</Table.Cell>
|
|
12
|
+
* <Table.Cell>2</Table.Cell>
|
|
13
|
+
* </Table.Row>
|
|
14
|
+
* </Table.Foot>
|
|
15
|
+
*/
|
|
5
16
|
const TableFoot = forwardRef(function TableFoot(rest, ref) {
|
|
6
17
|
return jsx("tfoot", { ref: ref, ...rest });
|
|
7
18
|
});
|
|
@@ -2,6 +2,17 @@
|
|
|
2
2
|
import { jsx } from 'react/jsx-runtime';
|
|
3
3
|
import { forwardRef } from 'react';
|
|
4
4
|
|
|
5
|
+
/**
|
|
6
|
+
* TableHead component, used to display the header of a table. Renders a native HTML thead element.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* <Table.Head>
|
|
10
|
+
* <Table.Row>
|
|
11
|
+
* <Table.HeaderCell>Name</Table.HeaderCell>
|
|
12
|
+
* <Table.HeaderCell>Age</Table.HeaderCell>
|
|
13
|
+
* </Table.Row>
|
|
14
|
+
* </Table.Head>
|
|
15
|
+
*/
|
|
5
16
|
const TableHead = forwardRef(function TableHead(rest, ref) {
|
|
6
17
|
return jsx("thead", { ref: ref, ...rest });
|
|
7
18
|
});
|
|
@@ -2,6 +2,12 @@
|
|
|
2
2
|
import { jsx } from 'react/jsx-runtime';
|
|
3
3
|
import { forwardRef } from 'react';
|
|
4
4
|
|
|
5
|
+
/**
|
|
6
|
+
* TableHeaderCell component, used to display the header cells of a table. Renders a native HTML th element.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* <Table.HeaderCell>Name</Table.HeaderCell>
|
|
10
|
+
*/
|
|
5
11
|
const TableHeaderCell = forwardRef(function TableHeaderCell({ sort, children, ...rest }, ref) {
|
|
6
12
|
return (jsx("th", { "aria-sort": sort, ref: ref, ...rest, children: sort ? jsx("button", { type: 'button', children: children }) : children }));
|
|
7
13
|
});
|
|
@@ -2,6 +2,15 @@
|
|
|
2
2
|
import { jsx } from 'react/jsx-runtime';
|
|
3
3
|
import { forwardRef } from 'react';
|
|
4
4
|
|
|
5
|
+
/**
|
|
6
|
+
* TableRow component, used to display the rows of a table. Renders a native HTML tr element.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* <Table.Row>
|
|
10
|
+
* <Table.Cell>John</Table.Cell>
|
|
11
|
+
* <Table.Cell>25</Table.Cell>
|
|
12
|
+
* </Table.Row>
|
|
13
|
+
*/
|
|
5
14
|
const TableRow = forwardRef(function TableRow(rest, ref) {
|
|
6
15
|
return jsx("tr", { ref: ref, ...rest });
|
|
7
16
|
});
|
|
@@ -7,6 +7,31 @@ import { TableHead } from './TableHead.js';
|
|
|
7
7
|
import { TableHeaderCell } from './TableHeaderCell.js';
|
|
8
8
|
import { TableRow } from './TableRow.js';
|
|
9
9
|
|
|
10
|
+
/**
|
|
11
|
+
* Table component, used to display tabular data. Renders a native HTML table element.
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* <Table>
|
|
15
|
+
* <Table.Head>
|
|
16
|
+
* <Table.Row>
|
|
17
|
+
* <Table.HeaderCell>Name</Table.HeaderCell>
|
|
18
|
+
* <Table.HeaderCell>Age</Table.HeaderCell>
|
|
19
|
+
* </Table.Row>
|
|
20
|
+
* </Table.Head>
|
|
21
|
+
* <Table.Body>
|
|
22
|
+
* <Table.Row>
|
|
23
|
+
* <Table.Cell>John</Table.Cell>
|
|
24
|
+
* <Table.Cell>25</Table.Cell>
|
|
25
|
+
* </Table.Row>
|
|
26
|
+
* </Table.Body>
|
|
27
|
+
* <Table.Foot>
|
|
28
|
+
* <Table.Row>
|
|
29
|
+
* <Table.Cell>Total</Table.Cell>
|
|
30
|
+
* <Table.Cell>2</Table.Cell>
|
|
31
|
+
* </Table.Row>
|
|
32
|
+
* </Table.Foot>
|
|
33
|
+
* </Table>
|
|
34
|
+
*/
|
|
10
35
|
const Table = Object.assign(Table$1, {
|
|
11
36
|
Head: TableHead,
|
|
12
37
|
Body: TableBody,
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
'use client';
|
|
2
2
|
import { jsx } from 'react/jsx-runtime';
|
|
3
3
|
import cl from 'clsx/lite';
|
|
4
|
-
import {
|
|
4
|
+
import { forwardRef, createContext, useState } from 'react';
|
|
5
5
|
|
|
6
6
|
const Context = createContext({});
|
|
7
7
|
/**
|
|
8
8
|
* Display a group of tabs that can be toggled between.
|
|
9
|
+
*
|
|
9
10
|
* @example
|
|
10
|
-
* ```tsx
|
|
11
11
|
* <Tabs onChange={(value) => console.log(value)}>
|
|
12
12
|
* <Tabs.List>
|
|
13
13
|
* <Tabs.Tab value='1'>Tab 1</Tabs.Tab>
|
|
@@ -18,7 +18,6 @@ const Context = createContext({});
|
|
|
18
18
|
* <Tabs.Panel value='2'>content 2</Tabs.Panel>
|
|
19
19
|
* <Tabs.Panel value='3'>content 3</Tabs.Panel>
|
|
20
20
|
* </Tabs>
|
|
21
|
-
* ```
|
|
22
21
|
*/
|
|
23
22
|
const Tabs = forwardRef(function Tabs({ value, defaultValue, className, onChange, ...rest }, ref) {
|
|
24
23
|
const isControlled = value !== undefined;
|
|
@@ -6,13 +6,12 @@ import { RovingFocusRoot } from '../../utilities/RovingFocus/RovingFocusRoot.js'
|
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* The container for all `Tab` components.
|
|
9
|
+
*
|
|
9
10
|
* @example
|
|
10
|
-
* ```tsx
|
|
11
11
|
* <Tabs.List>
|
|
12
12
|
* <Tabs.Tab value='1'>Tab 1</Tabs.Tab>
|
|
13
13
|
* <Tabs.Tab value='2'>Tab 2</Tabs.Tab>
|
|
14
14
|
* </Tabs.List>
|
|
15
|
-
* ```
|
|
16
15
|
*/
|
|
17
16
|
const TabsList = forwardRef(function TabsList({ children, ...rest }, ref) {
|
|
18
17
|
const { value } = useContext(Context);
|
|
@@ -6,10 +6,9 @@ import { Context } from './Tabs.js';
|
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* A single content item in a Tabs component.
|
|
9
|
+
*
|
|
9
10
|
* @example
|
|
10
|
-
* ```tsx
|
|
11
11
|
* <Tabs.Panel value='1'>content 1</Tabs.Panel>
|
|
12
|
-
* ```
|
|
13
12
|
*/
|
|
14
13
|
const TabsPanel = forwardRef(function TabsPanel({ children, value, ...rest }, ref) {
|
|
15
14
|
const { value: tabsValue } = useContext(Context);
|
|
@@ -6,8 +6,8 @@ import { TabsTab } from './TabsTab.js';
|
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* Display a group of tabs that can be toggled between.
|
|
9
|
+
*
|
|
9
10
|
* @example
|
|
10
|
-
* ```tsx
|
|
11
11
|
* <Tabs onChange={(value) => console.log(value)}>
|
|
12
12
|
* <Tabs.List>
|
|
13
13
|
* <Tabs.Tab value='1'>Tab 1</Tabs.Tab>
|
|
@@ -18,7 +18,6 @@ import { TabsTab } from './TabsTab.js';
|
|
|
18
18
|
* <Tabs.Panel value='2'>content 2</Tabs.Panel>
|
|
19
19
|
* <Tabs.Panel value='3'>content 3</Tabs.Panel>
|
|
20
20
|
* </Tabs>
|
|
21
|
-
* ```
|
|
22
21
|
*/
|
|
23
22
|
const Tabs = Object.assign(Tabs$1, {
|
|
24
23
|
List: TabsList,
|
|
@@ -4,9 +4,10 @@ import cl from 'clsx/lite';
|
|
|
4
4
|
import { forwardRef } from 'react';
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
|
-
* Use `Tag` to display
|
|
7
|
+
* Use `Tag` to display categories or statuses.
|
|
8
|
+
*
|
|
8
9
|
* @example
|
|
9
|
-
* <Tag>
|
|
10
|
+
* <Tag>Melk</Tag>
|
|
10
11
|
*/
|
|
11
12
|
const Tag = forwardRef(function Tag({ className, ...rest }, ref) {
|
|
12
13
|
return jsx("span", { className: cl('ds-tag', className), ref: ref, ...rest });
|
|
@@ -3,12 +3,11 @@ import { jsx } from 'react/jsx-runtime';
|
|
|
3
3
|
import cl from 'clsx/lite';
|
|
4
4
|
import { forwardRef } from 'react';
|
|
5
5
|
|
|
6
|
-
/**
|
|
6
|
+
/**
|
|
7
|
+
* Native HTML textarea element.
|
|
7
8
|
*
|
|
8
9
|
* @example
|
|
9
|
-
* ```tsx
|
|
10
10
|
* <Textarea />
|
|
11
|
-
* ```
|
|
12
11
|
*/
|
|
13
12
|
const Textarea = forwardRef(function Textarea({ className, ...rest }, ref) {
|
|
14
13
|
return (jsx("textarea", { className: cl('ds-input', className), ref: ref, ...rest }));
|
|
@@ -2,11 +2,11 @@
|
|
|
2
2
|
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
3
|
import { forwardRef } from 'react';
|
|
4
4
|
import { Field } from '../Field/index.js';
|
|
5
|
+
import { Label } from '../Label/Label.js';
|
|
5
6
|
import { FieldDescription } from '../Field/FieldDescription.js';
|
|
6
7
|
import { FieldAffixes, FieldAffix } from '../Field/FieldAffix.js';
|
|
7
8
|
import { Textarea } from '../Textarea/Textarea.js';
|
|
8
9
|
import { Input } from '../Input/Input.js';
|
|
9
|
-
import { Label } from '../Label/Label.js';
|
|
10
10
|
import { ValidationMessage } from '../ValidationMessage/ValidationMessage.js';
|
|
11
11
|
|
|
12
12
|
/**
|
|
@@ -16,9 +16,7 @@ import { ValidationMessage } from '../ValidationMessage/ValidationMessage.js';
|
|
|
16
16
|
*
|
|
17
17
|
* Rest props are passed to the `Input` or `Textarea` component.
|
|
18
18
|
* @example
|
|
19
|
-
* ```tsx
|
|
20
19
|
* <Textfield label="Textfield label">
|
|
21
|
-
* ```
|
|
22
20
|
*/
|
|
23
21
|
const Textfield = forwardRef(function Textfield({ label, description, error, multiline, prefix, suffix, 'data-size': size, counter, style, className, ...rest }, ref) {
|
|
24
22
|
return (jsxs(Field, { className: className, "data-size": size, style: style, children: [!!label && jsx(Label, { children: label }), !!description && jsx(FieldDescription, { children: description }), jsxs(FieldAffixes, { children: [prefix === undefined || jsx(FieldAffix, { children: prefix }), multiline === true ? (jsx(Textarea, { ref: ref, "aria-invalid": Boolean(error) || undefined, ...rest })) : (jsx(Input, { ref: ref, "aria-invalid": Boolean(error) || undefined, ...rest })), suffix === undefined || jsx(FieldAffix, { children: suffix })] }), !!error && jsx(ValidationMessage, { children: error }), !!counter && (jsx(Field.Counter, { ...(typeof counter === 'number' ? { limit: counter } : counter) }))] }));
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
'use client';
|
|
2
2
|
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
3
3
|
import cl from 'clsx/lite';
|
|
4
|
-
import {
|
|
4
|
+
import { forwardRef, useId, useState, createContext } from 'react';
|
|
5
5
|
import { RovingFocusRoot } from '../../utilities/RovingFocus/RovingFocusRoot.js';
|
|
6
6
|
|
|
7
7
|
const ToggleGroupContext = createContext({});
|
|
8
8
|
/**
|
|
9
9
|
* Display a group of buttons that can be toggled between.
|
|
10
|
+
*
|
|
10
11
|
* @example
|
|
11
12
|
* <ToggleGroup onChange={(value) => console.log(value)}>
|
|
12
13
|
* <ToggleGroup.Item value='1'>Toggle 1</ToggleGroup.Item>
|
|
@@ -4,17 +4,17 @@ import { ToggleGroupItem } from './ToggleGroupItem.js';
|
|
|
4
4
|
|
|
5
5
|
/**
|
|
6
6
|
* Display a group of buttons that can be toggled between.
|
|
7
|
+
*
|
|
7
8
|
* @example
|
|
8
|
-
* ```tsx
|
|
9
9
|
* <ToggleGroup onChange={(value) => console.log(value)}>
|
|
10
10
|
* <ToggleGroup.Item value='1'>Toggle 1</ToggleGroup.Item>
|
|
11
11
|
* <ToggleGroup.Item value='2'>Toggle 2</ToggleGroup.Item>
|
|
12
12
|
* <ToggleGroup.Item value='3'>Toggle 3</ToggleGroup.Item>
|
|
13
13
|
* </ToggleGroup>
|
|
14
|
-
* ```
|
|
15
14
|
*/
|
|
16
|
-
const ToggleGroup = ToggleGroup$1
|
|
17
|
-
|
|
15
|
+
const ToggleGroup = Object.assign(ToggleGroup$1, {
|
|
16
|
+
Item: ToggleGroupItem,
|
|
17
|
+
});
|
|
18
18
|
ToggleGroup.Item.displayName = 'ToggleGroup.Item';
|
|
19
19
|
|
|
20
20
|
export { ToggleGroup, ToggleGroupItem };
|
|
@@ -3,11 +3,12 @@ import { jsxs, Fragment as Fragment$1, jsx } from 'react/jsx-runtime';
|
|
|
3
3
|
import { autoUpdate, computePosition, offset, flip, shift } from '@floating-ui/dom';
|
|
4
4
|
import { Slot } from '@radix-ui/react-slot';
|
|
5
5
|
import cl from 'clsx/lite';
|
|
6
|
-
import { forwardRef, useId, useState, useRef, useEffect, Fragment } from 'react';
|
|
6
|
+
import { forwardRef, useId, useState, useRef, useEffect, Fragment, version } from 'react';
|
|
7
7
|
import { useMergeRefs } from '@floating-ui/react';
|
|
8
8
|
|
|
9
9
|
/**
|
|
10
10
|
* Tooltip component that displays a small piece of information when hovering or focusing on an element.
|
|
11
|
+
*
|
|
11
12
|
* @example
|
|
12
13
|
* <Tooltip content='This is a tooltip'>
|
|
13
14
|
* <button>Hover me</button>
|
|
@@ -80,10 +81,13 @@ const Tooltip = forwardRef(function Tooltip({ id, children, content, placement =
|
|
|
80
81
|
console.error('<Tooltip> children needs to be a single ReactElement that can receive a ref and not: <Fragment/> | <></>');
|
|
81
82
|
return null;
|
|
82
83
|
}
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
84
|
+
const popoverProps = {
|
|
85
|
+
[version.startsWith('19') ? 'popoverTarget' : 'popovertarget']: id ?? randomTooltipId,
|
|
86
|
+
[version.startsWith('19')
|
|
87
|
+
? 'popoverTargetAction'
|
|
88
|
+
: 'popovertargetaction']: 'show',
|
|
89
|
+
};
|
|
90
|
+
return (jsxs(Fragment$1, { children: [jsx(ChildContainer, { ref: triggerRef, ...popoverProps, onMouseEnter: setOpen, onMouseLeave: setClose, onFocus: setOpen, onBlur: setClose, children: children }), jsx("div", { ref: mergedRefs, role: 'tooltip', className: cl('ds-tooltip', className), id: id ?? randomTooltipId,
|
|
87
91
|
// @ts-ignore @types/react-dom does not understand popover yet
|
|
88
92
|
popover: 'manual', ...rest, children: content })] }));
|
|
89
93
|
});
|
|
@@ -4,7 +4,12 @@ import { Slot } from '@radix-ui/react-slot';
|
|
|
4
4
|
import cl from 'clsx/lite';
|
|
5
5
|
import { forwardRef } from 'react';
|
|
6
6
|
|
|
7
|
-
/**
|
|
7
|
+
/**
|
|
8
|
+
* Use `ValidationMessage` to display validation text
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* <ValidationMessage>This is a danger validation message</ValidationMessage>
|
|
12
|
+
*/
|
|
8
13
|
const ValidationMessage = forwardRef(function ValidationMessage({ className, asChild, ...rest }, ref) {
|
|
9
14
|
const Component = asChild ? Slot : 'p';
|
|
10
15
|
return (jsx(Component, { className: cl('ds-validation-message', className), "data-field": 'validation', ref: ref, ...rest }));
|