@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,13 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { Link } from '../Link/Link.js';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Link component used in ErrorSummary.
|
|
8
|
+
*/
|
|
9
|
+
const ErrorSummaryLink = forwardRef(function ErrorSummaryLink({ ...rest }, ref) {
|
|
10
|
+
return jsx(Link, { ref: ref, "data-color": 'neutral', ...rest });
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
export { ErrorSummaryLink };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { List } from '../List/index.js';
|
|
5
|
+
|
|
6
|
+
const ErrorSummaryList = forwardRef(function ErrorSummaryList({ ...rest }, ref) {
|
|
7
|
+
return jsx(List.Unordered, { ...rest, ref: ref });
|
|
8
|
+
});
|
|
9
|
+
|
|
10
|
+
export { ErrorSummaryList };
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { ErrorSummary as ErrorSummary$1 } from './ErrorSummary.js';
|
|
3
|
+
import { ErrorSummaryHeading } from './ErrorSummaryHeading.js';
|
|
4
|
+
import { ErrorSummaryItem } from './ErrorSummaryItem.js';
|
|
5
|
+
import { ErrorSummaryLink } from './ErrorSummaryLink.js';
|
|
6
|
+
import { ErrorSummaryList } from './ErrorSummaryList.js';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* ErrorSummary component, used to display a list of errors.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* <ErrorSummary>
|
|
13
|
+
* <ErrorSummary.Heading>Heading</ErrorSummary.Heading>
|
|
14
|
+
* <ErrorSummary.List>
|
|
15
|
+
* <ErrorSummary.Item>
|
|
16
|
+
* <ErrorSummary.Link href='#'>Error 1</ErrorSummary.Link>
|
|
17
|
+
* </ErrorSummary.Item>
|
|
18
|
+
* <ErrorSummary.Item>
|
|
19
|
+
* <ErrorSummary.Link href='#'>Error 2</ErrorSummary.Link>
|
|
20
|
+
* </ErrorSummary.Item>
|
|
21
|
+
* </ErrorSummary.List>
|
|
22
|
+
* </ErrorSummary>
|
|
23
|
+
*/
|
|
24
|
+
const ErrorSummary = Object.assign(ErrorSummary$1, {
|
|
25
|
+
Heading: ErrorSummaryHeading,
|
|
26
|
+
Item: ErrorSummaryItem,
|
|
27
|
+
List: ErrorSummaryList,
|
|
28
|
+
Link: ErrorSummaryLink,
|
|
29
|
+
});
|
|
30
|
+
ErrorSummary.Item.displayName = 'ErrorSummary.Item';
|
|
31
|
+
ErrorSummary.Heading.displayName = 'ErrorSummary.Heading';
|
|
32
|
+
ErrorSummary.List.displayName = 'ErrorSummary.List';
|
|
33
|
+
ErrorSummary.Link.displayName = 'ErrorSummary.Link';
|
|
34
|
+
|
|
35
|
+
export { ErrorSummary, ErrorSummaryHeading, ErrorSummaryItem, ErrorSummaryLink, ErrorSummaryList };
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { useMergeRefs } from '@floating-ui/react';
|
|
4
|
+
import cl from 'clsx/lite';
|
|
5
|
+
import { forwardRef, useRef, useEffect } from 'react';
|
|
6
|
+
import { fieldObserver } from './fieldObserver.js';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Field component, used to wrap a form field.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* <Field>
|
|
13
|
+
* <Label>Kort beskrivelse</Label>
|
|
14
|
+
* <Field.Description>Beskrivelse</Field.Description>
|
|
15
|
+
* <Input />
|
|
16
|
+
* <ValidationMessage>Feilmelding</ValidationMessage>
|
|
17
|
+
* </Field>
|
|
18
|
+
*/
|
|
19
|
+
const Field = forwardRef(function Field({ className, position, ...rest }, ref) {
|
|
20
|
+
const fieldRef = useRef(null);
|
|
21
|
+
const mergedRefs = useMergeRefs([fieldRef, ref]);
|
|
22
|
+
useEffect(() => fieldObserver(fieldRef.current), []);
|
|
23
|
+
return (jsx("div", { className: cl('ds-field', className), "data-position": position, ref: mergedRefs, ...rest }));
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
export { Field };
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import cl from 'clsx/lite';
|
|
4
|
+
import { forwardRef } from 'react';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* FieldAffixes component, used to wrap a form field.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* <Field.Affixes>
|
|
11
|
+
* <Field.Affix>NOK</Field.Affix>
|
|
12
|
+
* <Input />
|
|
13
|
+
* <Field.Affix>pr. mnd.</Field.Affix>
|
|
14
|
+
* </Field.Affixes>
|
|
15
|
+
*/
|
|
16
|
+
const FieldAffixes = forwardRef(function FieldAffixes({ className, ...rest }, ref) {
|
|
17
|
+
return (jsx("div", { className: cl('ds-field-affixes', className), ref: ref, ...rest }));
|
|
18
|
+
});
|
|
19
|
+
/**
|
|
20
|
+
* FieldAffix component, used to wrap a form field.
|
|
21
|
+
* Use together with Field.Affixes.
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* <Field.Affixes>
|
|
25
|
+
* <Field.Affix>NOK</Field.Affix>
|
|
26
|
+
* <Input />
|
|
27
|
+
* <Field.Affix>pr. mnd.</Field.Affix>
|
|
28
|
+
* </Field.Affixes>
|
|
29
|
+
*/
|
|
30
|
+
const FieldAffix = forwardRef(function FieldAffix({ className, ...rest }, ref) {
|
|
31
|
+
return (jsx("span", { className: cl('ds-field-affix', className), "aria-hidden": 'true', ref: ref, ...rest }));
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
export { FieldAffix, FieldAffixes };
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { forwardRef, useState, useRef, useEffect } from 'react';
|
|
4
|
+
import { isInputLike } from './fieldObserver.js';
|
|
5
|
+
import { ValidationMessage } from '../ValidationMessage/ValidationMessage.js';
|
|
6
|
+
import { Paragraph } from '../Paragraph/Paragraph.js';
|
|
7
|
+
|
|
8
|
+
const label = (text, count) => text.replace("%d", Math.abs(count).toString());
|
|
9
|
+
/**
|
|
10
|
+
* FieldCounter-komponent, används för att visa en räknare för ett formulärfält.
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* <Field>
|
|
14
|
+
* <Input />
|
|
15
|
+
* <Field.Counter limit={100} under='%d tecken kvar' over='%d tecken för mycket' />
|
|
16
|
+
* </Field>
|
|
17
|
+
*/
|
|
18
|
+
const FieldCounter = forwardRef(function FieldCounter({ limit, under = "%d tecken kvar", over = "%d tecken för mycket", ...rest }, ref) {
|
|
19
|
+
const [count, setCount] = useState(0);
|
|
20
|
+
const counterRef = useRef(null);
|
|
21
|
+
const hasExceededLimit = count > limit;
|
|
22
|
+
const remainder = limit - count;
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
const field = counterRef.current?.closest(".ds-field");
|
|
25
|
+
const input = Array.from(field?.getElementsByTagName("*") || []).find(isInputLike);
|
|
26
|
+
const onInput = ({ target }) => {
|
|
27
|
+
if (isInputLike(target))
|
|
28
|
+
setCount(target.value.length);
|
|
29
|
+
};
|
|
30
|
+
if (input)
|
|
31
|
+
onInput({ target: input }); // Initiering
|
|
32
|
+
field?.addEventListener("input", onInput);
|
|
33
|
+
return () => field?.removeEventListener("input", onInput);
|
|
34
|
+
}, []);
|
|
35
|
+
return (jsxs(Fragment, { children: [jsx("div", { "data-field": "description", className: "ds-sr-only", "aria-live": "polite", ref: counterRef, children: hasExceededLimit && label(over, remainder) }), hasExceededLimit ? (jsx(ValidationMessage, { ref: ref, ...rest, children: label(over, remainder) })) : (jsx(Paragraph, { ref: ref, ...rest, "data-field": "validation", children: label(under, remainder) }))] }));
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
export { FieldCounter };
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
|
|
5
|
+
const FieldDescription = forwardRef(function FieldDescription(rest, ref) {
|
|
6
|
+
return jsx("div", { "data-field": 'description', ref: ref, ...rest });
|
|
7
|
+
});
|
|
8
|
+
|
|
9
|
+
export { FieldDescription };
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
function fieldObserver(fieldElement) {
|
|
3
|
+
if (!fieldElement)
|
|
4
|
+
return;
|
|
5
|
+
const elements = new Map();
|
|
6
|
+
const uuid = `:${Date.now().toString(36)}${Math.random().toString(36).slice(2, 5)}`;
|
|
7
|
+
let input = null;
|
|
8
|
+
let describedby = '';
|
|
9
|
+
const process = (mutations) => {
|
|
10
|
+
const changed = [];
|
|
11
|
+
const removed = [];
|
|
12
|
+
// Merge MutationRecords
|
|
13
|
+
for (const mutation of mutations) {
|
|
14
|
+
if (mutation.attributeName)
|
|
15
|
+
changed.push(mutation.target ?? fieldElement);
|
|
16
|
+
changed.push(...(mutation.addedNodes || []));
|
|
17
|
+
removed.push(...(mutation.removedNodes || []));
|
|
18
|
+
}
|
|
19
|
+
// Register elements
|
|
20
|
+
for (const el of changed) {
|
|
21
|
+
if (!isElement(el))
|
|
22
|
+
continue;
|
|
23
|
+
if (isLabel(el))
|
|
24
|
+
elements.set(el, el.htmlFor);
|
|
25
|
+
else if (el.hasAttribute('data-field'))
|
|
26
|
+
elements.set(el, el.id);
|
|
27
|
+
else if (isInputLike(el)) {
|
|
28
|
+
input = el;
|
|
29
|
+
describedby = el.getAttribute('aria-describedby') || '';
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
// Reset removed elements
|
|
33
|
+
for (const el of removed) {
|
|
34
|
+
if (!isElement(el))
|
|
35
|
+
continue;
|
|
36
|
+
if (input === el)
|
|
37
|
+
input = null;
|
|
38
|
+
if (elements.has(el)) {
|
|
39
|
+
setAttr(el, 'aria-disabled', null); // Reset disabled state
|
|
40
|
+
setAttr(el, isLabel(el) ? 'for' : 'id', elements.get(el));
|
|
41
|
+
elements.delete(el);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
// Connect elements
|
|
45
|
+
const describedbyIds = [describedby]; // Keep original aria-describedby
|
|
46
|
+
const inputId = input?.id || uuid;
|
|
47
|
+
const isDisabled = input?.hasAttribute('disabled') ||
|
|
48
|
+
input?.getAttribute('aria-disabled') === 'true';
|
|
49
|
+
for (const [el, value] of elements) {
|
|
50
|
+
const descriptionType = el.getAttribute('data-field');
|
|
51
|
+
const id = descriptionType ? `${inputId}:${descriptionType}` : inputId;
|
|
52
|
+
setAttr(el, 'aria-disabled', isDisabled ? 'true' : null); // Forward inputs disabled state to related elements to make axe tests happy
|
|
53
|
+
if (!value)
|
|
54
|
+
setAttr(el, isLabel(el) ? 'for' : 'id', id); // Ensure we have a value
|
|
55
|
+
if (descriptionType === 'validation')
|
|
56
|
+
describedbyIds.unshift(el.id); // Validations to the front
|
|
57
|
+
else if (descriptionType)
|
|
58
|
+
describedbyIds.push(el.id); // Other descriptions to the back
|
|
59
|
+
}
|
|
60
|
+
setAttr(input, 'id', inputId);
|
|
61
|
+
setAttr(input, 'aria-describedby', describedbyIds.join(' ').trim());
|
|
62
|
+
};
|
|
63
|
+
const observer = createOptimizedMutationObserver(process);
|
|
64
|
+
observer.observe(fieldElement, {
|
|
65
|
+
attributeFilter: ['id', 'for', 'aria-describedby'],
|
|
66
|
+
attributes: true,
|
|
67
|
+
childList: true,
|
|
68
|
+
subtree: true,
|
|
69
|
+
});
|
|
70
|
+
process([{ addedNodes: fieldElement.querySelectorAll('*') }]); // Initial setup
|
|
71
|
+
observer.takeRecords(); // Clear initial setup queue
|
|
72
|
+
return () => observer.disconnect();
|
|
73
|
+
}
|
|
74
|
+
// Utilities
|
|
75
|
+
const isElement = (node) => node instanceof Element;
|
|
76
|
+
const isLabel = (node) => node instanceof HTMLLabelElement;
|
|
77
|
+
const isInputLike = (node) => node instanceof HTMLElement &&
|
|
78
|
+
'validity' in node &&
|
|
79
|
+
!(node instanceof HTMLButtonElement); // Matches input, textarea, select and form accosiated custom elements
|
|
80
|
+
const setAttr = (el, name, value) => value ? el?.setAttribute(name, value) : el?.removeAttribute(name);
|
|
81
|
+
// Speed up MutationObserver by debouncing, clearing internal queue after changes and only running when page is visible
|
|
82
|
+
function createOptimizedMutationObserver(callback) {
|
|
83
|
+
const queue = [];
|
|
84
|
+
const observer = new MutationObserver((mutations) => {
|
|
85
|
+
if (!queue.length)
|
|
86
|
+
requestAnimationFrame(process);
|
|
87
|
+
queue.push(...mutations);
|
|
88
|
+
});
|
|
89
|
+
const process = () => {
|
|
90
|
+
callback(queue, observer);
|
|
91
|
+
queue.length = 0; // Reset queue
|
|
92
|
+
observer.takeRecords(); // Clear queue due to DOM changes in callback
|
|
93
|
+
};
|
|
94
|
+
return observer;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
export { fieldObserver, isElement, isInputLike, isLabel };
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { Field as Field$1 } from './Field.js';
|
|
3
|
+
import { FieldAffix, FieldAffixes } from './FieldAffix.js';
|
|
4
|
+
import { FieldCounter } from './FieldCounter.js';
|
|
5
|
+
import { FieldDescription } from './FieldDescription.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Field component, used to wrap a form field.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* <Field data-my-field>
|
|
12
|
+
* <Label>Kort beskrivelse</Label>
|
|
13
|
+
* <Field.Description>Beskrivelse</Field.Description>
|
|
14
|
+
* <Input />
|
|
15
|
+
* <ValidationMessage>Feilmelding</ValidationMessage>
|
|
16
|
+
* </Field>
|
|
17
|
+
*/
|
|
18
|
+
const Field = Object.assign(Field$1, {
|
|
19
|
+
Description: FieldDescription,
|
|
20
|
+
Affixes: FieldAffixes,
|
|
21
|
+
Affix: FieldAffix,
|
|
22
|
+
Counter: FieldCounter,
|
|
23
|
+
});
|
|
24
|
+
Field.Description.displayName = 'Field.Description';
|
|
25
|
+
Field.Affixes.displayName = 'Field.Affixes';
|
|
26
|
+
Field.Affix.displayName = 'Field.Affix';
|
|
27
|
+
Field.Counter.displayName = 'Field.Counter';
|
|
28
|
+
|
|
29
|
+
export { Field, FieldAffix, FieldAffixes, FieldCounter, FieldDescription };
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import cl from 'clsx/lite';
|
|
4
|
+
import { forwardRef } from 'react';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Fieldset component, used to wrap a form field. Uses native `fieldset` element.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* <Fieldset>
|
|
11
|
+
* <Fieldset.Legend>Skriv inn dine svar</Fieldset.Legend>
|
|
12
|
+
* <Fieldset.Description>
|
|
13
|
+
* Gi en kort beskrivelse i begge feltene
|
|
14
|
+
* </Fieldset.Description>
|
|
15
|
+
* <Field>
|
|
16
|
+
* <Label>Kort beskrivelse</Label>
|
|
17
|
+
* <Input />
|
|
18
|
+
* </Field>
|
|
19
|
+
* </Fieldset>
|
|
20
|
+
*/
|
|
21
|
+
const Fieldset = forwardRef(function Fieldset({ className, ...rest }, ref) {
|
|
22
|
+
return (jsx("fieldset", { className: cl('ds-fieldset', className), ref: ref, ...rest }));
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
export { Fieldset };
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { Paragraph } from '../Paragraph/Paragraph.js';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* FieldsetDescription component, used to display a description for a fieldset.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* <Fieldset.Description>
|
|
11
|
+
* Gi en kort beskrivelse i begge feltene
|
|
12
|
+
* </Fieldset.Description>
|
|
13
|
+
*/
|
|
14
|
+
const FieldsetDescription = forwardRef(function FieldsetDescription(rest, ref) {
|
|
15
|
+
return jsx(Paragraph, { ref: ref, ...rest });
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
export { FieldsetDescription };
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { Label } from '../Label/Label.js';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* FieldsetLegend component, used to display a legend for a fieldset.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* <Fieldset.Legend>Skriv inn dine svar</Fieldset.Legend>
|
|
11
|
+
*/
|
|
12
|
+
const FieldsetLegend = forwardRef(function FieldsetLegend(rest, ref) {
|
|
13
|
+
return (jsx(Label, { asChild: true, children: jsx("legend", { ref: ref, ...rest }) }));
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
export { FieldsetLegend };
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { Fieldset as Fieldset$1 } from './Fieldset.js';
|
|
3
|
+
import { FieldsetDescription } from './FieldsetDescription.js';
|
|
4
|
+
import { FieldsetLegend } from './FieldsetLegend.js';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Fieldset component, used to wrap a form field.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* <Fieldset>
|
|
11
|
+
* <Fieldset.Legend>Skriv inn dine svar</Fieldset.Legend>
|
|
12
|
+
* <Fieldset.Description>
|
|
13
|
+
* Gi en kort beskrivelse i begge feltene
|
|
14
|
+
* </Fieldset.Description>
|
|
15
|
+
* <Field>
|
|
16
|
+
* <Label>Kort beskrivelse</Label>
|
|
17
|
+
* <Input />
|
|
18
|
+
* </Field>
|
|
19
|
+
* </Fieldset>
|
|
20
|
+
*/
|
|
21
|
+
const Fieldset = Object.assign(Fieldset$1, {
|
|
22
|
+
Legend: FieldsetLegend,
|
|
23
|
+
Description: FieldsetDescription,
|
|
24
|
+
});
|
|
25
|
+
Fieldset.Legend.displayName = 'Fieldset.Legend';
|
|
26
|
+
Fieldset.Description.displayName = 'Fieldset.Description';
|
|
27
|
+
|
|
28
|
+
export { Fieldset, FieldsetDescription, FieldsetLegend };
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
4
|
+
import cl from 'clsx/lite';
|
|
5
|
+
import { forwardRef } from 'react';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Use `Heading` to render h1-6 elements with heading text styles.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* <Heading data-size='lg' level={2}>Heading</Heading>
|
|
12
|
+
*/
|
|
13
|
+
const Heading = forwardRef(function Heading({ level = 2, className, asChild, ...rest }, ref) {
|
|
14
|
+
const Component = asChild ? Slot : `h${level}`;
|
|
15
|
+
return (jsx(Component, { className: cl("ds-heading", className), ref: ref, ...rest }));
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
export { Heading };
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
3
|
+
import cl from 'clsx/lite';
|
|
4
|
+
import { forwardRef } from 'react';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* InfoCards are used to inform users about summarized information.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* <InfoCard data-color='brand1' icon={<SomeIcon />} >
|
|
11
|
+
* <Heading level={2} data-size="lg">InfoCard Title</Heading>
|
|
12
|
+
* <Paragraph>This is an InfoCard component with brand1 color.</Paragraph>
|
|
13
|
+
* </InfoCard>
|
|
14
|
+
*/
|
|
15
|
+
const InfoCard = forwardRef(function InfoCard({ icon, "data-color": color, className, children, ...rest }, ref) {
|
|
16
|
+
return (jsx("div", { className: cl("ds-infocard", className), "data-color": color, ref: ref, ...rest, children: jsxs("div", { className: "ds-infocard__container", children: [icon && jsx(BoundingIcon, { Icon: icon }), jsx("div", { className: "ds-infocard__content", children: children })] }) }));
|
|
17
|
+
});
|
|
18
|
+
const BoundingIcon = ({ Icon }) => {
|
|
19
|
+
return (jsx("div", { className: "ds-bounding-icon", children: jsx("div", { className: "ds-bounding-icon__icon", children: Icon }) }));
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
export { InfoCard };
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import cl from 'clsx/lite';
|
|
4
|
+
import { forwardRef } from 'react';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Input renders a native `input` element.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* <Input />
|
|
11
|
+
*/
|
|
12
|
+
const Input = forwardRef(function Input({ type = 'text', className, onChange, onClick, ...rest }, ref) {
|
|
13
|
+
return (jsx("input", { className: cl(`ds-input`, className), ref: ref, type: type, onChange: (event) => rest.readOnly || onChange?.(event), onClick: (event) => {
|
|
14
|
+
if (rest.readOnly)
|
|
15
|
+
event.preventDefault(); // Make readonly work for checkbox / radio / switch
|
|
16
|
+
onClick?.(event);
|
|
17
|
+
}, ...rest }));
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
export { Input };
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
4
|
+
import cl from 'clsx/lite';
|
|
5
|
+
import { forwardRef } from 'react';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Use `Label` for labels. Renders a native `label` element.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* <Label data-size='lg' weight='medium'>Label</Label>
|
|
12
|
+
*/
|
|
13
|
+
const Label = forwardRef(function Label({ className, weight = "semibold", asChild, ...rest }, ref) {
|
|
14
|
+
const Component = asChild ? Slot : "label";
|
|
15
|
+
return (jsx(Component, { ref: ref, className: cl("ds-label", className), "data-weight": weight, ...rest }));
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
export { Label };
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
4
|
+
import cl from 'clsx/lite';
|
|
5
|
+
import { forwardRef } from 'react';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Link component, renders a native `a` element.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* <Link href='#'>Link</Link>
|
|
12
|
+
*/
|
|
13
|
+
const Link = forwardRef(({ asChild, className, ...rest }, ref) => {
|
|
14
|
+
const Component = asChild ? Slot : 'a';
|
|
15
|
+
return (jsx(Component, { className: cl('ds-link', className), ref: ref, ...rest }));
|
|
16
|
+
});
|
|
17
|
+
Link.displayName = 'Link';
|
|
18
|
+
|
|
19
|
+
export { Link };
|
|
@@ -0,0 +1,11 @@
|
|
|
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
|
+
const ListItem = forwardRef(function ListItem({ asChild, ...rest }, ref) {
|
|
7
|
+
const Component = asChild ? Slot : 'li';
|
|
8
|
+
return jsx(Component, { ...rest, ref: ref });
|
|
9
|
+
});
|
|
10
|
+
|
|
11
|
+
export { ListItem };
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
4
|
+
import cl from 'clsx/lite';
|
|
5
|
+
import { forwardRef } from 'react';
|
|
6
|
+
|
|
7
|
+
const render = (tagName, { asChild, className, ...rest }, ref) => {
|
|
8
|
+
const Component = asChild ? Slot : tagName;
|
|
9
|
+
return jsx(Component, { className: cl(`ds-list`, className), ref: ref, ...rest });
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* ListUnordered component, used to display a list of items.
|
|
13
|
+
* Renders a native `ul` element.
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* <List.Unordered>
|
|
17
|
+
* <List.Item>Item 1</List.Item>
|
|
18
|
+
* <List.Item>Item 2</List.Item>
|
|
19
|
+
* </List.Unordered>
|
|
20
|
+
*/
|
|
21
|
+
const ListUnordered = forwardRef(function ListUnordered(props, ref) {
|
|
22
|
+
return render('ul', props, ref);
|
|
23
|
+
});
|
|
24
|
+
/**
|
|
25
|
+
* ListOrdered component, used to display a list of items.
|
|
26
|
+
* Renders a native `ol` element.
|
|
27
|
+
*
|
|
28
|
+
* @example
|
|
29
|
+
* <List.Ordered>
|
|
30
|
+
* <List.Item>Item 1</List.Item>
|
|
31
|
+
* <List.Item>Item 2</List.Item>
|
|
32
|
+
* </List.Ordered>
|
|
33
|
+
*/
|
|
34
|
+
const ListOrdered = forwardRef(function ListOrdered(props, ref) {
|
|
35
|
+
return render('ol', props, ref);
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
export { ListOrdered, ListUnordered };
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { ListItem } from './ListItem.js';
|
|
3
|
+
import { ListUnordered, ListOrdered } from './Lists.js';
|
|
4
|
+
|
|
5
|
+
const List = {
|
|
6
|
+
Item: ListItem,
|
|
7
|
+
Ordered: ListOrdered,
|
|
8
|
+
Unordered: ListUnordered,
|
|
9
|
+
};
|
|
10
|
+
List.Item.displayName = 'List.Item';
|
|
11
|
+
List.Ordered.displayName = 'List.Ordered';
|
|
12
|
+
List.Unordered.displayName = 'List.Unordered';
|
|
13
|
+
|
|
14
|
+
export { List, ListItem, ListOrdered, ListUnordered };
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
4
|
+
import cl from 'clsx/lite';
|
|
5
|
+
import { forwardRef } from 'react';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Pagination component, used to navigate through a list of items.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* <Pagination>
|
|
12
|
+
* <Pagination.List>
|
|
13
|
+
* <Pagination.Item>
|
|
14
|
+
* <Pagination.Button aria-label='Forrige side'>Forrige</Pagination.Button>
|
|
15
|
+
* </Pagination.Item>
|
|
16
|
+
* <Pagination.Item>
|
|
17
|
+
* <Pagination.Button aria-label='Side 1'>1</Pagination.Button>
|
|
18
|
+
* </Pagination.Item>
|
|
19
|
+
* <Pagination.Item>
|
|
20
|
+
* <Pagination.Button aria-label='Side 2'>2</Pagination.Button>
|
|
21
|
+
* </Pagination.Item>
|
|
22
|
+
* </Pagination.List>
|
|
23
|
+
* </Pagination>
|
|
24
|
+
*/
|
|
25
|
+
const Pagination = forwardRef(function Pagination({ 'aria-label': ariaLabel = 'Sidenavigering', asChild, className, ...rest }, ref) {
|
|
26
|
+
const Component = asChild ? Slot : 'nav';
|
|
27
|
+
return (jsx(Component, { "aria-label": ariaLabel, className: cl('ds-pagination', className), ref: ref, ...rest }));
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
export { Pagination };
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { Button } from '../Button/Button.js';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* PaginationButton component, use within a Pagination.Item.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* <Pagination.Item>
|
|
11
|
+
* <Pagination.Button aria-label='Forrige side'>Forrige</Pagination.Button>
|
|
12
|
+
* </Pagination.Item>
|
|
13
|
+
*/
|
|
14
|
+
const PaginationButton = forwardRef(function PaginationButton(rest, ref) {
|
|
15
|
+
return jsx(Button, { ref: ref, ...rest });
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
export { PaginationButton };
|
|
@@ -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
|
+
* PaginationItem component, use within a Pagination.List.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* <Pagination.List>
|
|
11
|
+
* <Pagination.Item>
|
|
12
|
+
* <Pagination.Button aria-label='Forrige side'>Forrige</Pagination.Button>
|
|
13
|
+
* </Pagination.Item>
|
|
14
|
+
* </Pagination.List>
|
|
15
|
+
*/
|
|
16
|
+
const PaginationItem = forwardRef(function PaginationItem({ asChild, className, ...rest }, ref) {
|
|
17
|
+
const Component = asChild ? Slot : 'li';
|
|
18
|
+
return jsx(Component, { ref: ref, ...rest });
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
export { PaginationItem };
|
|
@@ -0,0 +1,23 @@
|
|
|
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
|
+
* PaginationList component, use within a Pagination.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* <Pagination>
|
|
11
|
+
* <Pagination.List>
|
|
12
|
+
* <Pagination.Item>
|
|
13
|
+
* <Pagination.Button aria-label='Forrige side'>Forrige</Pagination.Button>
|
|
14
|
+
* </Pagination.Item>
|
|
15
|
+
* </Pagination.List>
|
|
16
|
+
* </Pagination>
|
|
17
|
+
*/
|
|
18
|
+
const PaginationList = forwardRef(function PaginationList({ asChild, ...rest }, ref) {
|
|
19
|
+
const Component = asChild ? Slot : 'ul';
|
|
20
|
+
return jsx(Component, { ref: ref, ...rest });
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
export { PaginationList };
|