@bspk/ui 1.2.0 → 1.3.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/.scripts/index.ts +110 -0
- package/README.md +13 -0
- package/build.ts +2 -2
- package/dist/components/Accordion/Accordion.d.ts +42 -5
- package/dist/components/Accordion/Accordion.js +24 -20
- package/dist/components/Accordion/Accordion.js.map +1 -1
- package/dist/components/Accordion/AccordionExample.d.ts +2 -1
- package/dist/components/Accordion/AccordionExample.js +77 -64
- package/dist/components/Accordion/AccordionExample.js.map +1 -1
- package/dist/components/Accordion/accordion.css +37 -34
- package/dist/components/Accordion/accordion.css.js +37 -34
- package/dist/components/Avatar/Avatar.d.ts +10 -6
- package/dist/components/Avatar/Avatar.js +5 -10
- package/dist/components/Avatar/Avatar.js.map +1 -1
- package/dist/components/Avatar/AvatarExample.d.ts +2 -1
- package/dist/components/Avatar/AvatarExample.js +42 -41
- package/dist/components/Avatar/AvatarExample.js.map +1 -1
- package/dist/components/AvatarGroup/AvatarGroup.d.ts +1 -1
- package/dist/components/AvatarGroup/AvatarGroup.js +1 -1
- package/dist/components/AvatarGroup/AvatarGroup.js.map +1 -1
- package/dist/components/AvatarGroup/AvatarGroupExample.d.ts +2 -1
- package/dist/components/AvatarGroup/AvatarGroupExample.js +33 -27
- package/dist/components/AvatarGroup/AvatarGroupExample.js.map +1 -1
- package/dist/components/Badge/Badge.d.ts +1 -1
- package/dist/components/Badge/Badge.js +1 -1
- package/dist/components/Badge/Badge.js.map +1 -1
- package/dist/components/BadgeDot/BadgeDot.d.ts +1 -1
- package/dist/components/BadgeDot/BadgeDot.js +1 -1
- package/dist/components/BadgeDot/BadgeDot.js.map +1 -1
- package/dist/components/BannerAlert/BannerAlert.d.ts +1 -1
- package/dist/components/BannerAlert/BannerAlert.js +3 -2
- package/dist/components/BannerAlert/BannerAlert.js.map +1 -1
- package/dist/components/BannerAlert/BannerAlertExample.js +4 -0
- package/dist/components/BannerAlert/BannerAlertExample.js.map +1 -1
- package/dist/components/BannerAlert/banner-alert.css +0 -26
- package/dist/components/BannerAlert/banner-alert.css.js +0 -26
- package/dist/components/BottomNavigation/BottomNavigation.d.ts +53 -0
- package/dist/components/BottomNavigation/BottomNavigation.js +42 -0
- package/dist/components/BottomNavigation/BottomNavigation.js.map +1 -0
- package/dist/components/BottomNavigation/BottomNavigationExample.d.ts +4 -0
- package/dist/components/BottomNavigation/BottomNavigationExample.js +119 -0
- package/dist/components/BottomNavigation/BottomNavigationExample.js.map +1 -0
- package/dist/components/BottomNavigation/bottom-navigation.css +68 -0
- package/dist/components/BottomNavigation/bottom-navigation.css.js +73 -0
- package/dist/components/BottomNavigation/index.d.ts +1 -0
- package/dist/components/BottomNavigation/index.js +2 -0
- package/dist/components/BottomNavigation/index.js.map +1 -0
- package/dist/components/Breadcrumb/Breadcrumb.d.ts +4 -4
- package/dist/components/Breadcrumb/Breadcrumb.js +7 -16
- package/dist/components/Breadcrumb/Breadcrumb.js.map +1 -1
- package/dist/components/Breadcrumb/BreadcrumbExample.d.ts +2 -1
- package/dist/components/Breadcrumb/BreadcrumbExample.js +150 -149
- package/dist/components/Breadcrumb/BreadcrumbExample.js.map +1 -1
- package/dist/components/Button/Button.d.ts +1 -1
- package/dist/components/Button/Button.js +6 -3
- package/dist/components/Button/Button.js.map +1 -1
- package/dist/components/Button/ButtonExample.d.ts +2 -1
- package/dist/components/Button/ButtonExample.js +25 -24
- package/dist/components/Button/ButtonExample.js.map +1 -1
- package/dist/components/ButtonDock/ButtonDock.d.ts +55 -0
- package/dist/components/ButtonDock/ButtonDock.js +33 -0
- package/dist/components/ButtonDock/ButtonDock.js.map +1 -0
- package/dist/components/ButtonDock/ButtonDockExample.d.ts +4 -0
- package/dist/components/ButtonDock/ButtonDockExample.js +75 -0
- package/dist/components/ButtonDock/ButtonDockExample.js.map +1 -0
- package/dist/components/ButtonDock/button-dock.css +42 -0
- package/dist/components/ButtonDock/button-dock.css.js +47 -0
- package/dist/components/ButtonDock/index.d.ts +1 -0
- package/dist/components/ButtonDock/index.js +2 -0
- package/dist/components/ButtonDock/index.js.map +1 -0
- package/dist/components/CalendarPicker/CalendarPicker.d.ts +32 -0
- package/dist/components/CalendarPicker/CalendarPicker.js +203 -0
- package/dist/components/CalendarPicker/CalendarPicker.js.map +1 -0
- package/dist/components/CalendarPicker/CalendarPickerExample.d.ts +3 -0
- package/dist/components/CalendarPicker/CalendarPickerExample.js +17 -0
- package/dist/components/CalendarPicker/CalendarPickerExample.js.map +1 -0
- package/dist/components/CalendarPicker/calendar-picker.css +70 -0
- package/dist/components/CalendarPicker/calendar-picker.css.js +75 -0
- package/dist/components/CalendarPicker/index.d.ts +1 -0
- package/dist/components/CalendarPicker/index.js +2 -0
- package/dist/components/CalendarPicker/index.js.map +1 -0
- package/dist/components/Card/Card.d.ts +3 -9
- package/dist/components/Card/Card.js +2 -2
- package/dist/components/Card/Card.js.map +1 -1
- package/dist/components/Card/CardExample.js +1 -0
- package/dist/components/Card/CardExample.js.map +1 -1
- package/dist/components/Card/card.css +0 -4
- package/dist/components/Card/card.css.js +0 -4
- package/dist/components/Carousel/Carousel.d.ts +63 -0
- package/dist/components/Carousel/Carousel.js +68 -0
- package/dist/components/Carousel/Carousel.js.map +1 -0
- package/dist/components/Carousel/CarouselExample.d.ts +5 -0
- package/dist/components/Carousel/CarouselExample.js +51 -0
- package/dist/components/Carousel/CarouselExample.js.map +1 -0
- package/dist/components/Carousel/carousel.css +34 -0
- package/dist/components/Carousel/carousel.css.js +39 -0
- package/dist/components/Carousel/index.d.ts +1 -0
- package/dist/components/Carousel/index.js +2 -0
- package/dist/components/Carousel/index.js.map +1 -0
- package/dist/components/Checkbox/Checkbox.d.ts +1 -1
- package/dist/components/Checkbox/Checkbox.js +1 -1
- package/dist/components/Checkbox/Checkbox.js.map +1 -1
- package/dist/components/Checkbox/checkbox.css +8 -8
- package/dist/components/Checkbox/checkbox.css.js +8 -8
- package/dist/components/CheckboxGroup/CheckboxGroupExample.d.ts +2 -1
- package/dist/components/CheckboxGroup/CheckboxGroupExample.js +49 -42
- package/dist/components/CheckboxGroup/CheckboxGroupExample.js.map +1 -1
- package/dist/components/ChipAssist/ChipAssistExample.d.ts +2 -1
- package/dist/components/ChipAssist/ChipAssistExample.js +24 -23
- package/dist/components/ChipAssist/ChipAssistExample.js.map +1 -1
- package/dist/components/ChipFilter/ChipFilterExample.js +3 -0
- package/dist/components/ChipFilter/ChipFilterExample.js.map +1 -1
- package/dist/components/ChipGroup/ChipGroupExample.d.ts +2 -1
- package/dist/components/ChipGroup/ChipGroupExample.js +9 -8
- package/dist/components/ChipGroup/ChipGroupExample.js.map +1 -1
- package/dist/components/ChipInput/ChipInputExample.d.ts +2 -1
- package/dist/components/ChipInput/ChipInputExample.js +39 -38
- package/dist/components/ChipInput/ChipInputExample.js.map +1 -1
- package/dist/components/ChipSuggestion/ChipSuggestionExample.d.ts +2 -1
- package/dist/components/ChipSuggestion/ChipSuggestionExample.js +16 -15
- package/dist/components/ChipSuggestion/ChipSuggestionExample.js.map +1 -1
- package/dist/components/ChipUtility/ChipUtility.d.ts +1 -1
- package/dist/components/ChipUtility/ChipUtility.js +1 -1
- package/dist/components/ChipUtility/ChipUtility.js.map +1 -1
- package/dist/components/ChipUtility/ChipUtilityExample.d.ts +2 -1
- package/dist/components/ChipUtility/ChipUtilityExample.js +53 -52
- package/dist/components/ChipUtility/ChipUtilityExample.js.map +1 -1
- package/dist/components/DateField/DateField.d.ts +32 -0
- package/dist/components/DateField/DateField.js +34 -0
- package/dist/components/DateField/DateField.js.map +1 -0
- package/dist/components/DateField/DateFieldExample.d.ts +4 -0
- package/dist/components/DateField/DateFieldExample.js +11 -0
- package/dist/components/DateField/DateFieldExample.js.map +1 -0
- package/dist/components/DateField/date-field.css +8 -0
- package/dist/components/DateField/date-field.css.js +13 -0
- package/dist/components/DateField/index.d.ts +1 -0
- package/dist/components/DateField/index.js +2 -0
- package/dist/components/DateField/index.js.map +1 -0
- package/dist/components/DateInput/DateInput.d.ts +39 -0
- package/dist/components/DateInput/DateInput.js +102 -0
- package/dist/components/DateInput/DateInput.js.map +1 -0
- package/dist/components/DateInput/DateInputExample.d.ts +4 -0
- package/dist/components/DateInput/DateInputExample.js +14 -0
- package/dist/components/DateInput/DateInputExample.js.map +1 -0
- package/dist/components/DateInput/date-input.css +12 -0
- package/dist/components/DateInput/date-input.css.js +17 -0
- package/dist/components/DateInput/index.d.ts +1 -0
- package/dist/components/DateInput/index.js +2 -0
- package/dist/components/DateInput/index.js.map +1 -0
- package/dist/components/Dialog/Dialog.d.ts +15 -2
- package/dist/components/Dialog/Dialog.js +11 -9
- package/dist/components/Dialog/Dialog.js.map +1 -1
- package/dist/components/Dialog/DialogExample.d.ts +2 -1
- package/dist/components/Dialog/DialogExample.js +2 -0
- package/dist/components/Dialog/DialogExample.js.map +1 -1
- package/dist/components/Dialog/dialog.css +19 -67
- package/dist/components/Dialog/dialog.css.js +19 -67
- package/dist/components/Divider/Divider.d.ts +1 -1
- package/dist/components/Divider/Divider.js +1 -1
- package/dist/components/Divider/Divider.js.map +1 -1
- package/dist/components/Divider/DividerExample.d.ts +4 -2
- package/dist/components/Divider/DividerExample.js +2 -0
- package/dist/components/Divider/DividerExample.js.map +1 -1
- package/dist/components/Divider/divider.css +1 -1
- package/dist/components/Divider/divider.css.js +1 -1
- package/dist/components/Drawer/Drawer.d.ts +75 -0
- package/dist/components/Drawer/Drawer.js +49 -0
- package/dist/components/Drawer/Drawer.js.map +1 -0
- package/dist/components/Drawer/DrawerExample.d.ts +4 -0
- package/dist/components/Drawer/DrawerExample.js +47 -0
- package/dist/components/Drawer/DrawerExample.js.map +1 -0
- package/dist/components/Drawer/drawer.css +56 -0
- package/dist/components/Drawer/drawer.css.js +61 -0
- package/dist/components/Drawer/index.d.ts +1 -0
- package/dist/components/Drawer/index.js +2 -0
- package/dist/components/Drawer/index.js.map +1 -0
- package/dist/components/EmptyState/EmptyStateExample.d.ts +2 -1
- package/dist/components/EmptyState/EmptyStateExample.js +18 -11
- package/dist/components/EmptyState/EmptyStateExample.js.map +1 -1
- package/dist/components/Fab/Fab.d.ts +1 -1
- package/dist/components/Fab/Fab.js +5 -2
- package/dist/components/Fab/Fab.js.map +1 -1
- package/dist/components/Fab/FabExample.d.ts +1 -0
- package/dist/components/Fab/FabExample.js +4 -2
- package/dist/components/Fab/FabExample.js.map +1 -1
- package/dist/components/FileUpload/FileUpload.d.ts +1 -1
- package/dist/components/FileUpload/FileUpload.js +1 -1
- package/dist/components/FileUpload/FileUpload.js.map +1 -1
- package/dist/components/FileUpload/FileUploadExample.d.ts +2 -1
- package/dist/components/FileUpload/FileUploadExample.js +17 -16
- package/dist/components/FileUpload/FileUploadExample.js.map +1 -1
- package/dist/components/FileUploadItem/FileUploadItem.d.ts +1 -1
- package/dist/components/FileUploadItem/FileUploadItem.js +1 -1
- package/dist/components/FileUploadItem/FileUploadItem.js.map +1 -1
- package/dist/components/FileUploadItem/FileUploadItemExample.d.ts +2 -1
- package/dist/components/FileUploadItem/FileUploadItemExample.js +44 -39
- package/dist/components/FileUploadItem/FileUploadItemExample.js.map +1 -1
- package/dist/components/FormField/FormField.d.ts +3 -3
- package/dist/components/FormField/FormField.js +2 -2
- package/dist/components/FormField/FormField.js.map +1 -1
- package/dist/components/FormField/form-field.css +3 -3
- package/dist/components/FormField/form-field.css.js +3 -3
- package/dist/components/InlineAlert/InlineAlert.d.ts +1 -1
- package/dist/components/InlineAlert/InlineAlert.js +1 -1
- package/dist/components/InlineAlert/InlineAlert.js.map +1 -1
- package/dist/components/Layout/LayoutExample.d.ts +2 -1
- package/dist/components/Layout/LayoutExample.js +2 -0
- package/dist/components/Layout/LayoutExample.js.map +1 -1
- package/dist/components/Link/Link.d.ts +1 -1
- package/dist/components/Link/Link.js +1 -1
- package/dist/components/Link/Link.js.map +1 -1
- package/dist/components/Link/LinkExample.d.ts +2 -1
- package/dist/components/Link/LinkExample.js +2 -0
- package/dist/components/Link/LinkExample.js.map +1 -1
- package/dist/components/ListItem/ListItem.d.ts +40 -14
- package/dist/components/ListItem/ListItem.js +26 -13
- package/dist/components/ListItem/ListItem.js.map +1 -1
- package/dist/components/ListItem/ListItemExample.d.ts +2 -1
- package/dist/components/ListItem/ListItemExample.js +12 -12
- package/dist/components/ListItem/ListItemExample.js.map +1 -1
- package/dist/components/ListItem/list-item.css +10 -7
- package/dist/components/ListItem/list-item.css.js +10 -7
- package/dist/components/ListItemMenu/ListItemMenu.d.ts +146 -0
- package/dist/components/ListItemMenu/ListItemMenu.js +159 -0
- package/dist/components/ListItemMenu/ListItemMenu.js.map +1 -0
- package/dist/components/ListItemMenu/index.d.ts +1 -0
- package/dist/components/ListItemMenu/index.js +2 -0
- package/dist/components/ListItemMenu/index.js.map +1 -0
- package/dist/components/Menu/Menu.d.ts +12 -39
- package/dist/components/Menu/Menu.js +6 -26
- package/dist/components/Menu/Menu.js.map +1 -1
- package/dist/components/Menu/MenuExample.d.ts +3 -3
- package/dist/components/Menu/MenuExample.js +1 -24
- package/dist/components/Menu/MenuExample.js.map +1 -1
- package/dist/components/Menu/menu.css +3 -10
- package/dist/components/Menu/menu.css.js +3 -10
- package/dist/components/MenuButton/MenuButton.d.ts +1 -1
- package/dist/components/MenuButton/MenuButton.js +1 -1
- package/dist/components/MenuButton/MenuButton.js.map +1 -1
- package/dist/components/Modal/Modal.d.ts +4 -4
- package/dist/components/Modal/Modal.js +4 -4
- package/dist/components/Modal/Modal.js.map +1 -1
- package/dist/components/NumberInput/NumberInput.d.ts +8 -4
- package/dist/components/NumberInput/NumberInput.js +5 -14
- package/dist/components/NumberInput/NumberInput.js.map +1 -1
- package/dist/components/NumberInput/number-input.css +0 -1
- package/dist/components/NumberInput/number-input.css.js +0 -1
- package/dist/components/OTPInput/OTPInput.d.ts +3 -3
- package/dist/components/OTPInput/OTPInput.js +3 -3
- package/dist/components/OTPInput/OTPInput.js.map +1 -1
- package/dist/components/OTPInput/OTPInputExample.d.ts +2 -1
- package/dist/components/OTPInput/OTPInputExample.js +19 -16
- package/dist/components/OTPInput/OTPInputExample.js.map +1 -1
- package/dist/components/PageControl/PageControl.d.ts +5 -3
- package/dist/components/PageControl/PageControl.js +17 -16
- package/dist/components/PageControl/PageControl.js.map +1 -1
- package/dist/components/PageControl/PageControlExample.d.ts +4 -0
- package/dist/components/PageControl/PageControlExample.js +34 -0
- package/dist/components/PageControl/PageControlExample.js.map +1 -0
- package/dist/components/Pagination/Pagination.d.ts +1 -5
- package/dist/components/Pagination/Pagination.js +2 -6
- package/dist/components/Pagination/Pagination.js.map +1 -1
- package/dist/components/PasswordField/PasswordField.d.ts +2 -2
- package/dist/components/PasswordField/PasswordField.js +3 -3
- package/dist/components/PasswordField/PasswordField.js.map +1 -1
- package/dist/components/PasswordInput/PasswordInput.d.ts +1 -1
- package/dist/components/PasswordInput/PasswordInput.js +2 -2
- package/dist/components/PasswordInput/PasswordInput.js.map +1 -1
- package/dist/components/PhoneNumberInput/PhoneNumberInput.d.ts +3 -3
- package/dist/components/PhoneNumberInput/PhoneNumberInput.js +49 -52
- package/dist/components/PhoneNumberInput/PhoneNumberInput.js.map +1 -1
- package/dist/components/PhoneNumberInput/PhoneNumberInputExample.d.ts +4 -0
- package/dist/components/PhoneNumberInput/PhoneNumberInputExample.js +5 -0
- package/dist/components/PhoneNumberInput/PhoneNumberInputExample.js.map +1 -0
- package/dist/components/PhoneNumberInput/phone-number-input.css +36 -26
- package/dist/components/PhoneNumberInput/phone-number-input.css.js +36 -26
- package/dist/components/Popover/Popover.d.ts +7 -4
- package/dist/components/Popover/Popover.js +22 -19
- package/dist/components/Popover/Popover.js.map +1 -1
- package/dist/components/Popover/PopoverExample.js +7 -1
- package/dist/components/Popover/PopoverExample.js.map +1 -1
- package/dist/components/Popover/popover.css +3 -12
- package/dist/components/Popover/popover.css.js +3 -12
- package/dist/components/ProgressBar/ProgressBar.js +1 -1
- package/dist/components/ProgressBar/ProgressBar.js.map +1 -1
- package/dist/components/ProgressCircle/ProgressCircle.js +1 -1
- package/dist/components/ProgressCircle/ProgressCircle.js.map +1 -1
- package/dist/components/ProgressionStepper/ProgressionStepper.d.ts +1 -1
- package/dist/components/ProgressionStepper/ProgressionStepper.js +2 -2
- package/dist/components/ProgressionStepper/ProgressionStepper.js.map +1 -1
- package/dist/components/ProgressionStepper/ProgressionStepperExample.d.ts +2 -1
- package/dist/components/ProgressionStepper/ProgressionStepperExample.js +47 -46
- package/dist/components/ProgressionStepper/ProgressionStepperExample.js.map +1 -1
- package/dist/components/ProgressionStepperBar/ProgressionStepperBar.d.ts +1 -1
- package/dist/components/ProgressionStepperBar/ProgressionStepperBar.js +3 -3
- package/dist/components/ProgressionStepperBar/ProgressionStepperBar.js.map +1 -1
- package/dist/components/Radio/Radio.d.ts +1 -1
- package/dist/components/Radio/Radio.js.map +1 -1
- package/dist/components/RadioGroup/RadioGroup.d.ts +1 -1
- package/dist/components/RadioGroup/RadioGroup.js +2 -2
- package/dist/components/RadioGroup/RadioGroup.js.map +1 -1
- package/dist/components/RadioGroup/RadioGroupExample.d.ts +1 -0
- package/dist/components/RadioGroup/RadioGroupExample.js +2 -1
- package/dist/components/RadioGroup/RadioGroupExample.js.map +1 -1
- package/dist/components/RadioOption/RadioOption.js +1 -1
- package/dist/components/RadioOption/RadioOption.js.map +1 -1
- package/dist/components/Rating/Rating.js +2 -2
- package/dist/components/Rating/Rating.js.map +1 -1
- package/dist/components/Rating/RatingExample.d.ts +2 -1
- package/dist/components/Rating/RatingExample.js +9 -8
- package/dist/components/Rating/RatingExample.js.map +1 -1
- package/dist/components/Scrim/Scrim.d.ts +2 -2
- package/dist/components/Scrim/Scrim.js +2 -2
- package/dist/components/Scrim/Scrim.js.map +1 -1
- package/dist/components/Scrim/scrim.css +0 -3
- package/dist/components/Scrim/scrim.css.js +0 -3
- package/dist/components/SearchBar/SearchBar.d.ts +11 -8
- package/dist/components/SearchBar/SearchBar.js +46 -34
- package/dist/components/SearchBar/SearchBar.js.map +1 -1
- package/dist/components/SearchBar/SearchBarExample.d.ts +2 -1
- package/dist/components/SearchBar/SearchBarExample.js +2 -6
- package/dist/components/SearchBar/SearchBarExample.js.map +1 -1
- package/dist/components/SegmentedControl/SegmentedControl.d.ts +2 -2
- package/dist/components/SegmentedControl/SegmentedControl.js +1 -1
- package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
- package/dist/components/SegmentedControl/SegmentedControlExample.d.ts +2 -1
- package/dist/components/SegmentedControl/SegmentedControlExample.js +32 -23
- package/dist/components/SegmentedControl/SegmentedControlExample.js.map +1 -1
- package/dist/components/SegmentedControl/segmented-control.css +7 -7
- package/dist/components/SegmentedControl/segmented-control.css.js +7 -7
- package/dist/components/Select/Select.d.ts +53 -35
- package/dist/components/Select/Select.js +99 -27
- package/dist/components/Select/Select.js.map +1 -1
- package/dist/components/Select/SelectExample.d.ts +2 -1
- package/dist/components/Select/SelectExample.js +104 -89
- package/dist/components/Select/SelectExample.js.map +1 -1
- package/dist/components/Select/select.css +12 -18
- package/dist/components/Select/select.css.js +12 -18
- package/dist/components/SelectField/SelectFieldExample.d.ts +23 -0
- package/dist/components/SelectField/SelectFieldExample.js +13 -0
- package/dist/components/SelectField/SelectFieldExample.js.map +1 -0
- package/dist/components/Skeleton/SkeletonExample.d.ts +2 -1
- package/dist/components/Skeleton/SkeletonExample.js +10 -9
- package/dist/components/Skeleton/SkeletonExample.js.map +1 -1
- package/dist/components/SkeletonText/SkeletonTextExample.d.ts +2 -1
- package/dist/components/SkeletonText/SkeletonTextExample.js +12 -11
- package/dist/components/SkeletonText/SkeletonTextExample.js.map +1 -1
- package/dist/components/Slider/Slider.js +1 -1
- package/dist/components/Slider/Slider.js.map +1 -1
- package/dist/components/Slider/SliderExample.js +3 -0
- package/dist/components/Slider/SliderExample.js.map +1 -1
- package/dist/components/Snackbar/Snackbar.d.ts +27 -0
- package/dist/components/Snackbar/Snackbar.js +23 -0
- package/dist/components/Snackbar/Snackbar.js.map +1 -0
- package/dist/components/Snackbar/SnackbarExample.d.ts +3 -0
- package/dist/components/Snackbar/SnackbarExample.js +11 -0
- package/dist/components/Snackbar/SnackbarExample.js.map +1 -0
- package/dist/components/Snackbar/index.d.ts +1 -0
- package/dist/components/Snackbar/index.js +2 -0
- package/dist/components/Snackbar/index.js.map +1 -0
- package/dist/components/Snackbar/snackbar.css +19 -0
- package/dist/components/Snackbar/snackbar.css.js +24 -0
- package/dist/components/SnackbarProvider/SnackbarProvider.d.ts +90 -0
- package/dist/components/SnackbarProvider/SnackbarProvider.js +115 -0
- package/dist/components/SnackbarProvider/SnackbarProvider.js.map +1 -0
- package/dist/components/SnackbarProvider/SnackbarProviderExample.d.ts +4 -0
- package/dist/components/SnackbarProvider/SnackbarProviderExample.js +59 -0
- package/dist/components/SnackbarProvider/SnackbarProviderExample.js.map +1 -0
- package/dist/components/SnackbarProvider/index.d.ts +1 -0
- package/dist/components/SnackbarProvider/index.js +2 -0
- package/dist/components/SnackbarProvider/index.js.map +1 -0
- package/dist/components/SnackbarProvider/snackbar-provider-example.css +15 -0
- package/dist/components/SnackbarProvider/snackbar-provider-example.css.js +20 -0
- package/dist/components/SnackbarProvider/snackbar-provider.css +15 -0
- package/dist/components/SnackbarProvider/snackbar-provider.css.js +20 -0
- package/dist/components/Switch/Switch.d.ts +1 -1
- package/dist/components/Switch/Switch.js.map +1 -1
- package/dist/components/TabGroup/TabGroup.d.ts +1 -1
- package/dist/components/TabGroup/TabGroup.js +1 -1
- package/dist/components/TabGroup/TabGroup.js.map +1 -1
- package/dist/components/TabGroup/TabGroupExample.d.ts +2 -1
- package/dist/components/TabGroup/TabGroupExample.js +50 -45
- package/dist/components/TabGroup/TabGroupExample.js.map +1 -1
- package/dist/components/TabGroup/tab-group.css +6 -6
- package/dist/components/TabGroup/tab-group.css.js +6 -6
- package/dist/components/TabList/TabList.d.ts +1 -1
- package/dist/components/TabList/TabList.js +32 -22
- package/dist/components/TabList/TabList.js.map +1 -1
- package/dist/components/TabList/tab-list.css +6 -9
- package/dist/components/TabList/tab-list.css.js +6 -9
- package/dist/components/Tag/Tag.d.ts +1 -1
- package/dist/components/Tag/Tag.js +1 -1
- package/dist/components/Tag/Tag.js.map +1 -1
- package/dist/components/Tag/TagExample.d.ts +2 -1
- package/dist/components/Tag/TagExample.js +12 -11
- package/dist/components/Tag/TagExample.js.map +1 -1
- package/dist/components/TextField/TextField.js +1 -1
- package/dist/components/TextField/TextField.js.map +1 -1
- package/dist/components/TextField/TextFieldExample.d.ts +3 -0
- package/dist/components/TextField/TextFieldExample.js +6 -0
- package/dist/components/TextField/TextFieldExample.js.map +1 -0
- package/dist/components/TextInput/TextInput.d.ts +2 -2
- package/dist/components/TextInput/TextInput.js +27 -4
- package/dist/components/TextInput/TextInput.js.map +1 -1
- package/dist/components/TextInput/TextInputExample.js +9 -0
- package/dist/components/TextInput/TextInputExample.js.map +1 -1
- package/dist/components/TextInput/text-input.css +12 -25
- package/dist/components/TextInput/text-input.css.js +12 -25
- package/dist/components/Textarea/Textarea.d.ts +3 -3
- package/dist/components/Textarea/Textarea.js +2 -10
- package/dist/components/Textarea/Textarea.js.map +1 -1
- package/dist/components/TextareaField/TextareaField.d.ts +1 -1
- package/dist/components/TextareaField/TextareaField.js +2 -2
- package/dist/components/TextareaField/TextareaField.js.map +1 -1
- package/dist/components/TimeInput/Listbox.d.ts +10 -5
- package/dist/components/TimeInput/Listbox.js +14 -55
- package/dist/components/TimeInput/Listbox.js.map +1 -1
- package/dist/components/TimeInput/Segment.d.ts +3 -4
- package/dist/components/TimeInput/Segment.js +17 -13
- package/dist/components/TimeInput/Segment.js.map +1 -1
- package/dist/components/TimeInput/TimeInput.d.ts +3 -5
- package/dist/components/TimeInput/TimeInput.js +70 -23
- package/dist/components/TimeInput/TimeInput.js.map +1 -1
- package/dist/components/TimeInput/time-input.css +10 -9
- package/dist/components/TimeInput/time-input.css.js +10 -9
- package/dist/components/ToggleOption/ToggleOption.d.ts +1 -1
- package/dist/components/ToggleOption/ToggleOption.js.map +1 -1
- package/dist/components/Tooltip/Tooltip.d.ts +4 -3
- package/dist/components/Tooltip/Tooltip.js +12 -18
- package/dist/components/Tooltip/Tooltip.js.map +1 -1
- package/dist/components/Tooltip/TooltipExample.js +1 -1
- package/dist/components/Tooltip/TooltipExample.js.map +1 -1
- package/dist/components/Tooltip/tooltip.css +0 -2
- package/dist/components/Tooltip/tooltip.css.js +0 -2
- package/dist/components/Truncated/Truncated.d.ts +1 -0
- package/dist/components/Truncated/Truncated.js +2 -8
- package/dist/components/Truncated/Truncated.js.map +1 -1
- package/dist/components/Truncated/truncated.css +8 -0
- package/dist/components/Truncated/truncated.css.js +13 -0
- package/dist/components/UIProvider/AriaLiveMessageHandler.d.ts +13 -0
- package/dist/components/UIProvider/AriaLiveMessageHandler.js +30 -0
- package/dist/components/UIProvider/AriaLiveMessageHandler.js.map +1 -0
- package/dist/components/UIProvider/UIProvider.d.ts +12 -1
- package/dist/components/UIProvider/UIProvider.js +13 -4
- package/dist/components/UIProvider/UIProvider.js.map +1 -1
- package/dist/components/UIProvider/UIProviderExample.d.ts +5 -0
- package/dist/components/UIProvider/UIProviderExample.js +92 -0
- package/dist/components/UIProvider/UIProviderExample.js.map +1 -0
- package/dist/constants/phases.js +0 -1
- package/dist/constants/phases.js.map +1 -1
- package/dist/hooks/useAddEventListener.d.ts +2 -1
- package/dist/hooks/useAddEventListener.js.map +1 -1
- package/dist/hooks/useArrowNavigation.d.ts +50 -0
- package/dist/hooks/useArrowNavigation.js +57 -0
- package/dist/hooks/useArrowNavigation.js.map +1 -0
- package/dist/hooks/useCheckboxGroupState.d.ts +1 -1
- package/dist/hooks/useContainerWidth.d.ts +16 -0
- package/dist/hooks/useContainerWidth.js +35 -0
- package/dist/hooks/useContainerWidth.js.map +1 -0
- package/dist/hooks/useFloating.d.ts +7 -6
- package/dist/hooks/useFloating.js +10 -12
- package/dist/hooks/useFloating.js.map +1 -1
- package/dist/hooks/useSnackbarContext.d.ts +1 -0
- package/dist/hooks/useSnackbarContext.js +16 -0
- package/dist/hooks/useSnackbarContext.js.map +1 -0
- package/dist/hooks/useSwipe.d.ts +6 -0
- package/dist/hooks/useSwipe.js +28 -0
- package/dist/hooks/useSwipe.js.map +1 -0
- package/dist/styles/base.css +87 -15
- package/dist/styles/base.css.js +87 -15
- package/dist/types/common.d.ts +9 -4
- package/dist/types/common.js.map +1 -1
- package/dist/types/meta.d.ts +1 -1
- package/dist/types/meta.js +0 -7
- package/dist/types/meta.js.map +1 -1
- package/dist/utils/createExampleChildElement.js +1 -1
- package/dist/utils/createExampleChildElement.js.map +1 -1
- package/dist/utils/demo.d.ts +31 -6
- package/dist/utils/demo.js.map +1 -1
- package/dist/utils/dom.d.ts +2 -0
- package/dist/utils/dom.js +9 -0
- package/dist/utils/dom.js.map +1 -0
- package/dist/utils/handleKeyDown.d.ts +4 -3
- package/dist/utils/handleKeyDown.js +6 -3
- package/dist/utils/handleKeyDown.js.map +1 -1
- package/dist/utils/keyboard.d.ts +2 -1
- package/dist/utils/keyboard.js.map +1 -1
- package/dist/utils/scrollListItemsStyle.d.ts +10 -0
- package/dist/utils/scrollListItemsStyle.js +17 -0
- package/dist/utils/scrollListItemsStyle.js.map +1 -0
- package/dist/utils/snackbarContext.d.ts +38 -0
- package/dist/utils/snackbarContext.js +3 -0
- package/dist/utils/snackbarContext.js.map +1 -0
- package/dist/utils/uiContext.d.ts +6 -0
- package/dist/utils/uiContext.js.map +1 -1
- package/dist/utils/useIds.d.ts +4 -0
- package/dist/utils/useIds.js +11 -0
- package/dist/utils/useIds.js.map +1 -0
- package/package.json +41 -12
- package/src/components/Accordion/Accordion.rtl.test.tsx +17 -0
- package/src/components/Accordion/Accordion.tsx +87 -24
- package/src/components/Accordion/AccordionExample.tsx +78 -72
- package/src/components/Accordion/accordion.scss +37 -36
- package/src/components/Avatar/Avatar.rtl.test.tsx +16 -0
- package/src/components/Avatar/Avatar.tsx +30 -26
- package/src/components/Avatar/AvatarExample.tsx +44 -42
- package/src/components/AvatarGroup/AvatarGroup.rtl.test.tsx +16 -0
- package/src/components/AvatarGroup/AvatarGroup.tsx +1 -2
- package/src/components/AvatarGroup/AvatarGroupExample.tsx +36 -28
- package/src/components/Badge/Badge.rtl.test.tsx +19 -0
- package/src/components/Badge/Badge.tsx +1 -2
- package/src/components/BadgeDot/BadgeDot.rtl.test.tsx +19 -0
- package/src/components/BadgeDot/BadgeDot.tsx +1 -2
- package/src/components/BannerAlert/BannerAlert.rtl.test.tsx +26 -0
- package/src/components/BannerAlert/BannerAlert.tsx +16 -7
- package/src/components/BannerAlert/BannerAlertExample.tsx +4 -0
- package/src/components/BannerAlert/banner-alert.scss +0 -28
- package/src/components/BottomNavigation/BottomNavigation.rtl.test.tsx +21 -0
- package/src/components/BottomNavigation/BottomNavigation.tsx +60 -0
- package/src/components/BottomNavigation/BottomNavigationExample.tsx +121 -0
- package/src/components/BottomNavigation/bottom-navigation.scss +87 -0
- package/src/components/BottomNavigation/index.tsx +1 -0
- package/src/components/Breadcrumb/Breadcrumb.rtl.test.tsx +16 -0
- package/src/components/Breadcrumb/Breadcrumb.tsx +57 -73
- package/src/components/Breadcrumb/BreadcrumbExample.tsx +152 -150
- package/src/components/Button/Button.rtl.test.tsx +16 -0
- package/src/components/Button/Button.tsx +8 -5
- package/src/components/Button/ButtonExample.tsx +27 -25
- package/src/components/ButtonDock/ButtonDock.rtl.test.tsx +18 -0
- package/src/components/ButtonDock/ButtonDock.tsx +68 -0
- package/src/components/ButtonDock/ButtonDockExample.tsx +77 -0
- package/src/components/ButtonDock/button-dock.scss +49 -0
- package/src/components/ButtonDock/index.tsx +1 -0
- package/src/components/CalendarPicker/CalendarPicker.rtl.test.tsx +15 -0
- package/src/components/CalendarPicker/CalendarPicker.tsx +424 -0
- package/src/components/CalendarPicker/CalendarPickerExample.tsx +24 -0
- package/src/components/CalendarPicker/calendar-picker.scss +89 -0
- package/src/components/CalendarPicker/index.tsx +1 -0
- package/src/components/Card/Card.rtl.test.tsx +19 -0
- package/src/components/Card/Card.tsx +4 -11
- package/src/components/Card/CardExample.tsx +1 -0
- package/src/components/Card/card.scss +0 -5
- package/src/components/Carousel/Carousel.tsx +177 -0
- package/src/components/Carousel/CarouselExample.tsx +82 -0
- package/src/components/Carousel/carousel.scss +39 -0
- package/src/components/Carousel/index.tsx +1 -0
- package/src/components/Checkbox/Checkbox.rtl.test.tsx +27 -0
- package/src/components/Checkbox/Checkbox.tsx +1 -3
- package/src/components/Checkbox/checkbox.scss +4 -4
- package/src/components/CheckboxGroup/CheckboxGroup.rtl.test.tsx +19 -0
- package/src/components/CheckboxGroup/CheckboxGroupExample.tsx +51 -43
- package/src/components/CheckboxOption/CheckboxOption.rtl.test.tsx +24 -0
- package/src/components/ChipAssist/ChipAssist.rtl.test.tsx +16 -0
- package/src/components/ChipAssist/ChipAssistExample.tsx +26 -24
- package/src/components/ChipFilter/ChipFilter.rtl.test.tsx +15 -0
- package/src/components/ChipFilter/ChipFilterExample.tsx +3 -0
- package/src/components/ChipGroup/ChipGroup.rtl.test.tsx +32 -0
- package/src/components/ChipGroup/ChipGroupExample.tsx +11 -9
- package/src/components/ChipInput/ChipInput.rtl.test.tsx +16 -0
- package/src/components/ChipInput/ChipInputExample.tsx +41 -39
- package/src/components/ChipSuggestion/ChipSuggestion.rtl.test.tsx +19 -0
- package/src/components/ChipSuggestion/ChipSuggestionExample.tsx +18 -16
- package/src/components/ChipUtility/ChipUtility.rtl.test.tsx +16 -0
- package/src/components/ChipUtility/ChipUtility.tsx +1 -3
- package/src/components/ChipUtility/ChipUtilityExample.tsx +56 -54
- package/src/components/DateField/DateField.rtl.test.tsx +24 -0
- package/src/components/DateField/DateField.tsx +58 -0
- package/src/components/DateField/DateFieldExample.tsx +13 -0
- package/src/components/DateField/date-field.scss +8 -0
- package/src/components/DateField/index.tsx +1 -0
- package/src/components/DateInput/DateInput.rtl.test.tsx +17 -0
- package/src/components/DateInput/DateInput.tsx +197 -0
- package/src/components/DateInput/DateInputExample.tsx +17 -0
- package/src/components/DateInput/date-input.scss +13 -0
- package/src/components/DateInput/index.tsx +1 -0
- package/src/components/Dialog/Dialog.rtl.test.tsx +22 -0
- package/src/components/Dialog/Dialog.tsx +26 -7
- package/src/components/Dialog/DialogExample.tsx +4 -1
- package/src/components/Dialog/dialog.scss +25 -79
- package/src/components/Divider/Divider.rtl.test.tsx +8 -0
- package/src/components/Divider/Divider.tsx +1 -2
- package/src/components/Divider/DividerExample.tsx +6 -2
- package/src/components/Divider/divider.scss +1 -1
- package/src/components/Drawer/Drawer.rtl.test.tsx +27 -0
- package/src/components/Drawer/Drawer.tsx +135 -0
- package/src/components/Drawer/DrawerExample.tsx +93 -0
- package/src/components/Drawer/drawer.scss +67 -0
- package/src/components/Drawer/index.tsx +1 -0
- package/src/components/EmptyState/EmptyState.rtl.test.tsx +16 -0
- package/src/components/EmptyState/EmptyStateExample.tsx +24 -16
- package/src/components/Fab/Fab.rtl.test.tsx +15 -0
- package/src/components/Fab/Fab.tsx +6 -4
- package/src/components/Fab/FabExample.tsx +5 -2
- package/src/components/FileUpload/FileUpload.rtl.test.tsx +14 -0
- package/src/components/FileUpload/FileUpload.tsx +1 -2
- package/src/components/FileUpload/FileUploadExample.tsx +19 -17
- package/src/components/FileUploadItem/FileUploadItem.rtl.test.tsx +19 -0
- package/src/components/FileUploadItem/FileUploadItem.tsx +1 -3
- package/src/components/FileUploadItem/FileUploadItemExample.tsx +47 -40
- package/src/components/FormField/FormField.rtl.test.tsx +30 -0
- package/src/components/FormField/FormField.tsx +3 -4
- package/src/components/FormField/form-field.scss +1 -1
- package/src/components/Img/Img.rtl.test.tsx +15 -0
- package/src/components/InlineAlert/InlineAlert.rtl.test.tsx +15 -0
- package/src/components/InlineAlert/InlineAlert.tsx +1 -2
- package/src/components/Layout/Layout.rtl.test.tsx +15 -0
- package/src/components/Layout/LayoutExample.tsx +4 -1
- package/src/components/Link/Link.rtl.test.tsx +14 -0
- package/src/components/Link/Link.tsx +1 -3
- package/src/components/Link/LinkExample.tsx +4 -1
- package/src/components/ListItem/ListItem.rtl.test.tsx +18 -0
- package/src/components/ListItem/ListItem.tsx +132 -73
- package/src/components/ListItem/ListItemExample.tsx +14 -13
- package/src/components/ListItem/list-item.scss +16 -10
- package/src/components/ListItemMenu/ListItemMenu.tsx +358 -0
- package/src/components/ListItemMenu/index.tsx +1 -0
- package/src/components/Menu/Menu.rtl.test.tsx +15 -0
- package/src/components/Menu/Menu.tsx +39 -106
- package/src/components/Menu/MenuExample.tsx +2 -32
- package/src/components/Menu/menu.scss +4 -16
- package/src/components/MenuButton/MenuButton.rtl.test.tsx +15 -0
- package/src/components/MenuButton/MenuButton.tsx +1 -3
- package/src/components/Modal/Modal.rtl.test.tsx +20 -0
- package/src/components/Modal/Modal.tsx +8 -5
- package/src/components/NumberField/NumberField.rtl.test.tsx +24 -0
- package/src/components/NumberInput/NumberInput.rtl.test.tsx +15 -0
- package/src/components/NumberInput/NumberInput.tsx +16 -22
- package/src/components/NumberInput/number-input.scss +0 -1
- package/src/components/OTPInput/OTPInput.rtl.test.tsx +19 -0
- package/src/components/OTPInput/OTPInput.tsx +3 -4
- package/src/components/OTPInput/OTPInputExample.tsx +21 -17
- package/src/components/PageControl/PageControl.rtl.test.tsx +15 -0
- package/src/components/PageControl/PageControl.tsx +23 -23
- package/src/components/PageControl/PageControlExample.tsx +36 -0
- package/src/components/Pagination/Pagination.rtl.test.tsx +15 -0
- package/src/components/Pagination/Pagination.tsx +2 -7
- package/src/components/PasswordField/PasswordField.rtl.test.tsx +24 -0
- package/src/components/PasswordField/PasswordField.tsx +4 -5
- package/src/components/PasswordInput/PasswordInput.rtl.test.tsx +15 -0
- package/src/components/PasswordInput/PasswordInput.tsx +2 -2
- package/src/components/PhoneNumberField/PhoneNumberField.rtl.test.tsx +24 -0
- package/src/components/PhoneNumberInput/PhoneNumberInput.rtl.test.tsx +17 -0
- package/src/components/PhoneNumberInput/PhoneNumberInput.tsx +103 -144
- package/src/components/PhoneNumberInput/PhoneNumberInputExample.tsx +8 -0
- package/src/components/PhoneNumberInput/phone-number-input.scss +40 -31
- package/src/components/Popover/Popover.rtl.test.tsx +28 -0
- package/src/components/Popover/Popover.tsx +82 -72
- package/src/components/Popover/PopoverExample.tsx +7 -1
- package/src/components/Popover/popover.scss +3 -13
- package/src/components/Portal/Portal.rtl.test.tsx +15 -0
- package/src/components/ProgressBar/ProgressBar.rtl.test.tsx +15 -0
- package/src/components/ProgressBar/ProgressBar.tsx +1 -2
- package/src/components/ProgressCircle/ProgressCircle.rtl.test.tsx +15 -0
- package/src/components/ProgressCircle/ProgressCircle.tsx +1 -2
- package/src/components/ProgressionStepper/ProgressionStepper.rtl.test.tsx +19 -0
- package/src/components/ProgressionStepper/ProgressionStepper.tsx +2 -4
- package/src/components/ProgressionStepper/ProgressionStepperExample.tsx +49 -47
- package/src/components/ProgressionStepperBar/ProgressionStepperBar.rtl.test.tsx +15 -0
- package/src/components/ProgressionStepperBar/ProgressionStepperBar.tsx +9 -4
- package/src/components/Radio/Radio.rtl.test.tsx +15 -0
- package/src/components/Radio/Radio.tsx +1 -3
- package/src/components/RadioGroup/RadioGroup.rtl.test.tsx +32 -0
- package/src/components/RadioGroup/RadioGroup.tsx +2 -3
- package/src/components/RadioGroup/RadioGroupExample.tsx +3 -1
- package/src/components/RadioOption/RadioOption.rtl.test.tsx +15 -0
- package/src/components/RadioOption/RadioOption.tsx +1 -1
- package/src/components/Rating/Rating.rtl.test.tsx +16 -0
- package/src/components/Rating/Rating.tsx +9 -12
- package/src/components/Rating/RatingExample.tsx +11 -9
- package/src/components/Scrim/Scrim.rtl.test.tsx +15 -0
- package/src/components/Scrim/Scrim.tsx +11 -4
- package/src/components/Scrim/scrim.scss +0 -4
- package/src/components/SearchBar/SearchBar.rtl.test.tsx +41 -0
- package/src/components/SearchBar/SearchBar.tsx +95 -89
- package/src/components/SearchBar/SearchBarExample.tsx +3 -20
- package/src/components/SegmentedControl/SegmentedControl.rtl.test.tsx +26 -0
- package/src/components/SegmentedControl/SegmentedControl.tsx +2 -4
- package/src/components/SegmentedControl/SegmentedControlExample.tsx +34 -24
- package/src/components/SegmentedControl/segmented-control.scss +19 -14
- package/src/components/Select/Select.rtl.test.tsx +25 -0
- package/src/components/Select/Select.tsx +229 -102
- package/src/components/Select/SelectExample.tsx +111 -91
- package/src/components/Select/select.scss +13 -23
- package/src/components/SelectField/SelectField.rtl.test.tsx +25 -0
- package/src/components/SelectField/SelectFieldExample.tsx +16 -0
- package/src/components/Skeleton/Skeleton.rtl.test.tsx +16 -0
- package/src/components/Skeleton/SkeletonExample.tsx +12 -10
- package/src/components/SkeletonText/SkeletonText.rtl.test.tsx +16 -0
- package/src/components/SkeletonText/SkeletonTextExample.tsx +14 -13
- package/src/components/Slider/Slider.rtl.test.tsx +8 -0
- package/src/components/Slider/Slider.tsx +1 -2
- package/src/components/Slider/SliderExample.tsx +3 -0
- package/src/components/Snackbar/Snackbar.tsx +48 -0
- package/src/components/Snackbar/SnackbarExample.tsx +12 -0
- package/src/components/Snackbar/index.tsx +1 -0
- package/src/components/Snackbar/snackbar.scss +22 -0
- package/src/components/SnackbarProvider/SnackbarProvider.tsx +160 -0
- package/src/components/SnackbarProvider/SnackbarProviderExample.tsx +127 -0
- package/src/components/SnackbarProvider/index.tsx +1 -0
- package/src/components/SnackbarProvider/snackbar-provider-example.scss +17 -0
- package/src/components/SnackbarProvider/snackbar-provider.scss +15 -0
- package/src/components/Switch/Switch.rtl.test.tsx +15 -0
- package/src/components/Switch/Switch.tsx +1 -3
- package/src/components/SwitchOption/SwitchOption.rtl.test.tsx +15 -0
- package/src/components/TabGroup/TabGroup.rtl.test.tsx +19 -0
- package/src/components/TabGroup/TabGroup.tsx +1 -2
- package/src/components/TabGroup/TabGroupExample.tsx +52 -46
- package/src/components/TabGroup/tab-group.scss +7 -5
- package/src/components/TabList/TabList.rtl.test.tsx +26 -0
- package/src/components/TabList/TabList.tsx +36 -31
- package/src/components/TabList/tab-list.scss +6 -9
- package/src/components/Table/Table.rtl.test.tsx +28 -0
- package/src/components/Tag/Tag.rtl.test.tsx +20 -0
- package/src/components/Tag/Tag.tsx +1 -3
- package/src/components/Tag/TagExample.tsx +14 -12
- package/src/components/TextField/TextField.rtl.test.tsx +24 -0
- package/src/components/TextField/TextField.tsx +0 -1
- package/src/components/TextField/TextFieldExample.tsx +8 -0
- package/src/components/TextInput/TextInput.rtl.test.tsx +17 -0
- package/src/components/TextInput/TextInput.tsx +46 -12
- package/src/components/TextInput/TextInputExample.tsx +9 -0
- package/src/components/TextInput/text-input.scss +9 -31
- package/src/components/Textarea/Textarea.rtl.test.tsx +17 -0
- package/src/components/Textarea/Textarea.tsx +5 -16
- package/src/components/TextareaField/TextareaField.rtl.test.tsx +24 -0
- package/src/components/TextareaField/TextareaField.tsx +2 -0
- package/src/components/TimeInput/Listbox.tsx +37 -64
- package/src/components/TimeInput/Segment.tsx +31 -21
- package/src/components/TimeInput/TimeInput.rtl.test.tsx +15 -0
- package/src/components/TimeInput/TimeInput.tsx +132 -65
- package/src/components/TimeInput/time-input.scss +5 -4
- package/src/components/ToggleOption/ToggleOption.rtl.test.tsx +15 -0
- package/src/components/ToggleOption/ToggleOption.tsx +1 -2
- package/src/components/Tooltip/Tooltip.rtl.test.tsx +24 -0
- package/src/components/Tooltip/Tooltip.tsx +14 -31
- package/src/components/Tooltip/TooltipExample.tsx +6 -8
- package/src/components/Tooltip/tooltip.scss +0 -2
- package/src/components/TopNavigation/TopNavigation.rtl.test.tsx +15 -0
- package/src/components/Truncated/Truncated.rtl.test.tsx +15 -0
- package/src/components/Truncated/Truncated.tsx +2 -9
- package/src/components/Truncated/truncated.scss +8 -0
- package/src/components/Txt/Txt.rtl.test.tsx +15 -0
- package/src/components/UIProvider/AriaLiveMessageHandler.tsx +44 -0
- package/src/components/UIProvider/UIProvider.tsx +16 -2
- package/src/components/UIProvider/UIProviderExample.tsx +146 -0
- package/src/constants/phases.ts +0 -1
- package/src/hooks/useAddEventListener.ts +3 -1
- package/src/hooks/useArrowNavigation.ts +107 -0
- package/src/hooks/useContainerWidth.tsx +37 -0
- package/src/hooks/useFloating.ts +20 -19
- package/src/hooks/useSnackbarContext.ts +18 -0
- package/src/hooks/useSwipe.ts +32 -0
- package/src/rtl/hasNoBasicA11yIssues.tsx +27 -0
- package/src/rtl/util.tsx +10 -0
- package/src/styles/base.scss +131 -70
- package/src/types/common.ts +9 -4
- package/src/types/meta.ts +1 -9
- package/src/utils/createExampleChildElement.tsx +1 -1
- package/src/utils/demo.ts +41 -7
- package/src/utils/dom.ts +6 -0
- package/src/utils/handleKeyDown.ts +11 -6
- package/src/utils/keyboard.ts +3 -0
- package/src/utils/scrollListItemsStyle.ts +29 -0
- package/src/utils/snackbarContext.tsx +43 -0
- package/src/utils/uiContext.ts +4 -1
- package/src/utils/useIds.ts +16 -0
- package/tsconfig.build.json +21 -0
- package/tsconfig.json +9 -1
- package/dist/components/Accordion/AccordionSection.d.ts +0 -84
- package/dist/components/Accordion/AccordionSection.js +0 -27
- package/dist/components/Accordion/AccordionSection.js.map +0 -1
- package/dist/components/Combobox/Combobox.d.ts +0 -92
- package/dist/components/Combobox/Combobox.js +0 -58
- package/dist/components/Combobox/Combobox.js.map +0 -1
- package/dist/components/Combobox/ListItems.d.ts +0 -26
- package/dist/components/Combobox/ListItems.js +0 -22
- package/dist/components/Combobox/ListItems.js.map +0 -1
- package/dist/components/Combobox/index.d.ts +0 -1
- package/dist/components/Combobox/index.js +0 -2
- package/dist/components/Combobox/index.js.map +0 -1
- package/dist/components/Listbox/Listbox.d.ts +0 -116
- package/dist/components/Listbox/Listbox.js +0 -83
- package/dist/components/Listbox/Listbox.js.map +0 -1
- package/dist/components/Listbox/index.d.ts +0 -1
- package/dist/components/Listbox/index.js +0 -2
- package/dist/components/Listbox/index.js.map +0 -1
- package/dist/hooks/useCombobox.d.ts +0 -56
- package/dist/hooks/useCombobox.js +0 -104
- package/dist/hooks/useCombobox.js.map +0 -1
- package/dist/hooks/useKeyNavigation.d.ts +0 -17
- package/dist/hooks/useKeyNavigation.js +0 -46
- package/dist/hooks/useKeyNavigation.js.map +0 -1
- package/src/components/Accordion/AccordionSection.tsx +0 -128
- package/src/components/Combobox/Combobox.tsx +0 -224
- package/src/components/Combobox/ListItems.tsx +0 -107
- package/src/components/Combobox/index.tsx +0 -1
- package/src/components/Listbox/Listbox.tsx +0 -257
- package/src/components/Listbox/index.tsx +0 -1
- package/src/hooks/useCombobox.ts +0 -173
- package/src/hooks/useKeyNavigation.ts +0 -66
- package/src/utils/placeholder.test.ts +0 -7
|
@@ -1,6 +1,6 @@
|
|
|
1
|
+
import './modal.scss';
|
|
1
2
|
import { SvgClose } from '@bspk/icons/Close';
|
|
2
3
|
import { ReactNode, useMemo, useRef } from 'react';
|
|
3
|
-
|
|
4
4
|
import { Button, ButtonProps } from '-/components/Button';
|
|
5
5
|
import { DialogProps, Dialog } from '-/components/Dialog';
|
|
6
6
|
import { Txt } from '-/components/Txt';
|
|
@@ -9,8 +9,6 @@ import { useDebounceCallback } from '-/hooks/useDebounceCallback';
|
|
|
9
9
|
import { useUIContext } from '-/hooks/useUIContext';
|
|
10
10
|
import { CallToActionButton } from '-/types/common';
|
|
11
11
|
|
|
12
|
-
import './modal.scss';
|
|
13
|
-
|
|
14
12
|
// This hook is used to set the height of the modal based on the dialog box height.
|
|
15
13
|
// It listens to the resize event and updates the modal height accordingly.
|
|
16
14
|
function useDialogHeight() {
|
|
@@ -46,7 +44,10 @@ function useDialogHeight() {
|
|
|
46
44
|
|
|
47
45
|
export type ModalCallToAction = Pick<ButtonProps, 'destructive'> & Pick<CallToActionButton, 'label' | 'onClick'>;
|
|
48
46
|
|
|
49
|
-
export type ModalProps = Pick<
|
|
47
|
+
export type ModalProps = Pick<
|
|
48
|
+
DialogProps,
|
|
49
|
+
'container' | 'disableFocusTrap' | 'id' | 'innerRef' | 'onClose' | 'open' | 'owner'
|
|
50
|
+
> & {
|
|
50
51
|
/**
|
|
51
52
|
* Modal header.
|
|
52
53
|
*
|
|
@@ -118,7 +119,7 @@ export type ModalProps = Pick<DialogProps, 'container' | 'id' | 'innerRef' | 'on
|
|
|
118
119
|
*
|
|
119
120
|
* return (
|
|
120
121
|
* <>
|
|
121
|
-
* <Button label="Open
|
|
122
|
+
* <Button label="Open Modal" onClick={() => setOpen(true)} />
|
|
122
123
|
* <Modal
|
|
123
124
|
* description="Example description"
|
|
124
125
|
* header="Example header"
|
|
@@ -144,6 +145,7 @@ export function Modal({
|
|
|
144
145
|
cancelButton,
|
|
145
146
|
buttonFormat = 'horizontal',
|
|
146
147
|
innerRef,
|
|
148
|
+
disableFocusTrap,
|
|
147
149
|
...dialogProps
|
|
148
150
|
}: ModalProps) {
|
|
149
151
|
const { isMobile } = useUIContext();
|
|
@@ -178,6 +180,7 @@ export function Modal({
|
|
|
178
180
|
{...dialogProps}
|
|
179
181
|
aria-description={description}
|
|
180
182
|
aria-label={header}
|
|
183
|
+
disableFocusTrap={disableFocusTrap}
|
|
181
184
|
innerRef={setModalRefs}
|
|
182
185
|
placement="center"
|
|
183
186
|
showScrim
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { NumberField } from './NumberField';
|
|
2
|
+
import { hasNoBasicA11yIssues } from '-/rtl/hasNoBasicA11yIssues';
|
|
3
|
+
import { render } from '-/rtl/util';
|
|
4
|
+
|
|
5
|
+
const TestBed = () => (
|
|
6
|
+
<NumberField
|
|
7
|
+
aria-label="Example label"
|
|
8
|
+
controlId="Example controlId"
|
|
9
|
+
label="Example label"
|
|
10
|
+
name="Example name"
|
|
11
|
+
onChange={() => {}}
|
|
12
|
+
value={24}
|
|
13
|
+
/>
|
|
14
|
+
);
|
|
15
|
+
|
|
16
|
+
describe('NumberField (RTL)', () => {
|
|
17
|
+
it('has no basic a11y issues', hasNoBasicA11yIssues(<TestBed />));
|
|
18
|
+
|
|
19
|
+
it('renders', () => {
|
|
20
|
+
const { getByLabelText } = render(<TestBed />);
|
|
21
|
+
|
|
22
|
+
expect(getByLabelText('Example label')).toBeInTheDocument();
|
|
23
|
+
});
|
|
24
|
+
});
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { NumberInput } from './NumberInput';
|
|
2
|
+
import { hasNoBasicA11yIssues } from '-/rtl/hasNoBasicA11yIssues';
|
|
3
|
+
import { render } from '-/rtl/util';
|
|
4
|
+
|
|
5
|
+
const TestBed = () => <NumberInput aria-label="Example label" name="Example name" onChange={() => {}} value={24} />;
|
|
6
|
+
|
|
7
|
+
describe('NumberInput (RTL)', () => {
|
|
8
|
+
it('has no basic a11y issues', hasNoBasicA11yIssues(<TestBed />));
|
|
9
|
+
|
|
10
|
+
it('renders', () => {
|
|
11
|
+
const { getByLabelText } = render(<TestBed />);
|
|
12
|
+
|
|
13
|
+
expect(getByLabelText('Example label')).toBeInTheDocument();
|
|
14
|
+
});
|
|
15
|
+
});
|
|
@@ -1,20 +1,9 @@
|
|
|
1
|
+
import './number-input.scss';
|
|
1
2
|
import { useCallback, useState } from 'react';
|
|
2
3
|
import { IncrementButton } from './IncrementButton';
|
|
3
4
|
import { useId } from '-/hooks/useId';
|
|
4
5
|
import { CommonProps, FormFieldControlProps } from '-/types/common';
|
|
5
6
|
|
|
6
|
-
import './number-input.scss';
|
|
7
|
-
|
|
8
|
-
const MAX = 100;
|
|
9
|
-
const MIN = 0;
|
|
10
|
-
|
|
11
|
-
const DEFAULT = {
|
|
12
|
-
align: 'center',
|
|
13
|
-
size: 'medium',
|
|
14
|
-
disabled: false,
|
|
15
|
-
readOnly: false,
|
|
16
|
-
} as const;
|
|
17
|
-
|
|
18
7
|
function isNumber(value: unknown, fallbackValue: number | undefined = undefined): number | undefined {
|
|
19
8
|
if (typeof value === 'number') return value;
|
|
20
9
|
if (typeof value !== 'string') return fallbackValue;
|
|
@@ -43,8 +32,6 @@ export type NumberInputProps = CommonProps<
|
|
|
43
32
|
/**
|
|
44
33
|
* Defines the [maximum](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/max) value that is
|
|
45
34
|
* accepted.
|
|
46
|
-
*
|
|
47
|
-
* @default 99
|
|
48
35
|
*/
|
|
49
36
|
max?: number;
|
|
50
37
|
/**
|
|
@@ -54,6 +41,12 @@ export type NumberInputProps = CommonProps<
|
|
|
54
41
|
* @default 0
|
|
55
42
|
*/
|
|
56
43
|
min?: number;
|
|
44
|
+
/**
|
|
45
|
+
* The amount to increment or decrement the value by when the (+) or (-) buttons are pressed.
|
|
46
|
+
*
|
|
47
|
+
* @default 1
|
|
48
|
+
*/
|
|
49
|
+
step?: number;
|
|
57
50
|
};
|
|
58
51
|
|
|
59
52
|
/**
|
|
@@ -84,31 +77,31 @@ export type NumberInputProps = CommonProps<
|
|
|
84
77
|
export function NumberInput({
|
|
85
78
|
value,
|
|
86
79
|
onChange,
|
|
87
|
-
align =
|
|
88
|
-
size =
|
|
89
|
-
disabled =
|
|
90
|
-
readOnly =
|
|
80
|
+
align = 'center',
|
|
81
|
+
size = 'medium',
|
|
82
|
+
disabled = false,
|
|
83
|
+
readOnly = false,
|
|
91
84
|
name,
|
|
92
85
|
id: inputIdProp,
|
|
93
86
|
'aria-label': ariaLabel,
|
|
94
87
|
max: maxProp,
|
|
95
|
-
min
|
|
88
|
+
min = 0,
|
|
96
89
|
invalid,
|
|
97
90
|
'aria-describedby': ariaDescribedBy,
|
|
98
91
|
'aria-errormessage': ariaErrorMessage,
|
|
92
|
+
step = 1,
|
|
99
93
|
...inputElementProps
|
|
100
94
|
}: NumberInputProps) {
|
|
95
|
+
const max = typeof maxProp === 'number' && maxProp >= min ? maxProp : Number.MAX_SAFE_INTEGER;
|
|
101
96
|
const centered = align !== 'left';
|
|
102
97
|
const inputId = useId(inputIdProp);
|
|
103
|
-
const max = Math.min(MAX, isNumber(maxProp) || MAX);
|
|
104
|
-
const min = Math.max(MIN, isNumber(minProp) || MIN);
|
|
105
98
|
const valueNumber = isNumber(value) || 0;
|
|
106
99
|
|
|
107
100
|
const [inputElement, setInputElement] = useState<HTMLInputElement | null>(null);
|
|
108
101
|
|
|
109
102
|
const handleIncrement = (increment: -1 | 1) => {
|
|
110
103
|
if (!inputElement) return;
|
|
111
|
-
const nextValue = (isNumber(inputElement.value) || 0) + increment;
|
|
104
|
+
const nextValue = (isNumber(inputElement.value) || 0) + increment * step;
|
|
112
105
|
handleUpdate(nextValue);
|
|
113
106
|
};
|
|
114
107
|
|
|
@@ -159,6 +152,7 @@ export function NumberInput({
|
|
|
159
152
|
}}
|
|
160
153
|
readOnly={readOnly}
|
|
161
154
|
ref={(node) => node && setInputElement(node)}
|
|
155
|
+
step={step}
|
|
162
156
|
type="number"
|
|
163
157
|
/>
|
|
164
158
|
{!centered && (
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { OTPInput } from './OTPInput';
|
|
2
|
+
import { presets } from './OTPInputExample';
|
|
3
|
+
import { hasNoBasicA11yIssues } from '-/rtl/hasNoBasicA11yIssues';
|
|
4
|
+
import { render } from '-/rtl/util';
|
|
5
|
+
|
|
6
|
+
describe('OTPInput (RTL)', () => {
|
|
7
|
+
presets.forEach((preset) => {
|
|
8
|
+
it(
|
|
9
|
+
`has no basic a11y issues - ${preset.label}`,
|
|
10
|
+
hasNoBasicA11yIssues(<OTPInput onChange={() => {}} {...preset.propState} />),
|
|
11
|
+
);
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
it('renders', () => {
|
|
15
|
+
const { getByLabelText } = render(<OTPInput onChange={() => {}} {...presets[0].propState} />);
|
|
16
|
+
|
|
17
|
+
expect(getByLabelText('OTP digit 1')).toBeInTheDocument();
|
|
18
|
+
});
|
|
19
|
+
});
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
+
import './otp-input.scss';
|
|
1
2
|
import { useRef } from 'react';
|
|
2
3
|
import { useId } from '-/hooks/useId';
|
|
3
4
|
import { CommonProps } from '-/types/common';
|
|
4
5
|
|
|
5
|
-
import './otp-input.scss';
|
|
6
|
-
|
|
7
6
|
export type OTPInputProps = CommonProps<'id' | 'invalid' | 'name' | 'size'> & {
|
|
8
7
|
/**
|
|
9
8
|
* The value of the otp-input.
|
|
@@ -30,7 +29,7 @@ export type OTPInputProps = CommonProps<'id' | 'invalid' | 'name' | 'size'> & {
|
|
|
30
29
|
};
|
|
31
30
|
|
|
32
31
|
/**
|
|
33
|
-
* A row of
|
|
32
|
+
* A row of input fields that are used to input a temporary secure pin code sent to the customer.
|
|
34
33
|
*
|
|
35
34
|
* @example
|
|
36
35
|
* import { OTPInput } from '@bspk/ui/OTPInput';
|
|
@@ -40,7 +39,7 @@ export type OTPInputProps = CommonProps<'id' | 'invalid' | 'name' | 'size'> & {
|
|
|
40
39
|
* }
|
|
41
40
|
*
|
|
42
41
|
* @name OTPInput
|
|
43
|
-
* @phase
|
|
42
|
+
* @phase UXReview
|
|
44
43
|
*/
|
|
45
44
|
export function OTPInput({
|
|
46
45
|
value: valueProp,
|
|
@@ -1,26 +1,30 @@
|
|
|
1
1
|
import { OTPInputProps } from '.';
|
|
2
|
-
import { ComponentExample } from '-/utils/demo';
|
|
2
|
+
import { ComponentExample, Preset } from '-/utils/demo';
|
|
3
|
+
|
|
4
|
+
export const presets: Preset<OTPInputProps>[] = [
|
|
5
|
+
{
|
|
6
|
+
label: '4 Characters',
|
|
7
|
+
propState: {
|
|
8
|
+
value: '',
|
|
9
|
+
length: 4,
|
|
10
|
+
name: 'OTP Input',
|
|
11
|
+
},
|
|
12
|
+
},
|
|
13
|
+
{
|
|
14
|
+
label: '6 Characters',
|
|
15
|
+
propState: {
|
|
16
|
+
value: '',
|
|
17
|
+
length: 6,
|
|
18
|
+
name: 'OTP Input',
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
];
|
|
3
22
|
|
|
4
23
|
export const OTPInputExample: ComponentExample<OTPInputProps> = {
|
|
5
24
|
containerStyle: { width: '100%' },
|
|
6
25
|
defaultState: {},
|
|
7
26
|
disableProps: [],
|
|
8
|
-
presets
|
|
9
|
-
{
|
|
10
|
-
label: '4 Characters',
|
|
11
|
-
propState: {
|
|
12
|
-
value: '',
|
|
13
|
-
length: 4,
|
|
14
|
-
},
|
|
15
|
-
},
|
|
16
|
-
{
|
|
17
|
-
label: '6 Characters',
|
|
18
|
-
propState: {
|
|
19
|
-
value: '',
|
|
20
|
-
length: 6,
|
|
21
|
-
},
|
|
22
|
-
},
|
|
23
|
-
],
|
|
27
|
+
presets,
|
|
24
28
|
render: ({ props, Component }) => <Component {...props} />,
|
|
25
29
|
sections: [],
|
|
26
30
|
};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { PageControl } from './PageControl';
|
|
2
|
+
import { hasNoBasicA11yIssues } from '-/rtl/hasNoBasicA11yIssues';
|
|
3
|
+
import { render } from '-/rtl/util';
|
|
4
|
+
|
|
5
|
+
const TestBed = () => <PageControl currentPage={1} numPages={3} />;
|
|
6
|
+
|
|
7
|
+
describe('PageControl (RTL)', () => {
|
|
8
|
+
it('has no basic a11y issues', hasNoBasicA11yIssues(<TestBed />));
|
|
9
|
+
|
|
10
|
+
it('renders', () => {
|
|
11
|
+
const { getByLabelText } = render(<TestBed />);
|
|
12
|
+
|
|
13
|
+
expect(getByLabelText('Page 1 of 3')).toBeInTheDocument();
|
|
14
|
+
});
|
|
15
|
+
});
|
|
@@ -4,21 +4,22 @@ const MAX_DOT_COUNT = 5 as const;
|
|
|
4
4
|
|
|
5
5
|
export type PageControlProps = {
|
|
6
6
|
/**
|
|
7
|
-
* The current page
|
|
7
|
+
* The current page (NOT zero-based).
|
|
8
8
|
*
|
|
9
9
|
* @example
|
|
10
10
|
* 1;
|
|
11
11
|
*
|
|
12
|
+
* @min 1
|
|
12
13
|
* @required
|
|
13
14
|
*/
|
|
14
|
-
|
|
15
|
-
|
|
15
|
+
currentPage: number;
|
|
16
16
|
/**
|
|
17
17
|
* The total number of pages.
|
|
18
18
|
*
|
|
19
19
|
* @example
|
|
20
20
|
* 5;
|
|
21
21
|
*
|
|
22
|
+
* @min 1
|
|
22
23
|
* @required
|
|
23
24
|
*/
|
|
24
25
|
numPages: number;
|
|
@@ -46,21 +47,24 @@ type DotSize = 'medium' | 'small' | 'x-small';
|
|
|
46
47
|
* @name PageControl
|
|
47
48
|
* @phase UXReview
|
|
48
49
|
*/
|
|
49
|
-
export function PageControl({
|
|
50
|
-
|
|
50
|
+
export function PageControl({ currentPage: currentProp, numPages: numPagesProp, variant = 'flat' }: PageControlProps) {
|
|
51
|
+
const numPages = Number(numPagesProp);
|
|
52
|
+
const current = Number(currentProp);
|
|
53
|
+
|
|
54
|
+
if (numPages < 2 || current < 1 || current > numPages) return null;
|
|
51
55
|
|
|
52
56
|
return (
|
|
53
57
|
<span
|
|
54
|
-
aria-label={`Page ${
|
|
58
|
+
aria-label={`Page ${current} of ${numPages}`}
|
|
55
59
|
data-bspk="page-control"
|
|
56
60
|
data-variant={variant || undefined}
|
|
57
61
|
role="img"
|
|
58
62
|
>
|
|
59
|
-
{getDots(
|
|
63
|
+
{getDots(current - 1, numPages).map(({ pageIndex, size }, index) => (
|
|
60
64
|
<span
|
|
61
65
|
aria-hidden="true"
|
|
62
|
-
data-active={
|
|
63
|
-
data-dot={
|
|
66
|
+
data-active={pageIndex + 1 === current || undefined}
|
|
67
|
+
data-dot={pageIndex}
|
|
64
68
|
data-size={size}
|
|
65
69
|
key={index + 1}
|
|
66
70
|
role="presentation"
|
|
@@ -70,29 +74,25 @@ export function PageControl({ value, numPages, variant = 'flat' }: PageControlPr
|
|
|
70
74
|
);
|
|
71
75
|
}
|
|
72
76
|
|
|
73
|
-
function getDots(
|
|
77
|
+
function getDots(currentIndex: number, totalPages: number) {
|
|
74
78
|
if (totalPages <= MAX_DOT_COUNT) {
|
|
75
79
|
return Array.from({ length: totalPages }, (_, i) => ({
|
|
76
80
|
size: 'medium' as DotSize,
|
|
77
|
-
|
|
81
|
+
pageIndex: i,
|
|
78
82
|
}));
|
|
79
83
|
}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
const dots = Array.from({ length: MAX_DOT_COUNT }, (_, i) => {
|
|
84
|
-
const page = start + i;
|
|
84
|
+
const start = Math.max(0, Math.min(currentIndex - 2, totalPages - MAX_DOT_COUNT));
|
|
85
|
+
return Array.from({ length: MAX_DOT_COUNT }, (_, i) => {
|
|
86
|
+
const pageIndex = start + i;
|
|
85
87
|
let size: DotSize = 'medium';
|
|
86
88
|
|
|
87
|
-
if (i === 0 &&
|
|
88
|
-
if (i === 1 &&
|
|
89
|
-
if (i === 3 &&
|
|
90
|
-
if (i === 4 &&
|
|
89
|
+
if (i === 0 && pageIndex > 0) size = 'x-small';
|
|
90
|
+
if (i === 1 && pageIndex > 1) size = 'small';
|
|
91
|
+
if (i === 3 && pageIndex < totalPages - 2) size = 'small';
|
|
92
|
+
if (i === 4 && pageIndex < totalPages - 1) size = 'x-small';
|
|
91
93
|
|
|
92
|
-
return {
|
|
94
|
+
return { pageIndex, size };
|
|
93
95
|
});
|
|
94
|
-
|
|
95
|
-
return dots;
|
|
96
96
|
}
|
|
97
97
|
|
|
98
98
|
/** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { PageControlProps } from '.';
|
|
2
|
+
import { ComponentExample, Preset } from '-/utils/demo';
|
|
3
|
+
|
|
4
|
+
export const presets: Preset<PageControlProps>[] = [
|
|
5
|
+
{
|
|
6
|
+
label: '6 pages, on page 2',
|
|
7
|
+
propState: {
|
|
8
|
+
numPages: 6,
|
|
9
|
+
currentPage: 2,
|
|
10
|
+
},
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
label: '5 pages, on page 1',
|
|
14
|
+
propState: {
|
|
15
|
+
numPages: 5,
|
|
16
|
+
currentPage: 1,
|
|
17
|
+
},
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
label: '10 pages, on page 10',
|
|
21
|
+
propState: {
|
|
22
|
+
numPages: 10,
|
|
23
|
+
currentPage: 10,
|
|
24
|
+
},
|
|
25
|
+
},
|
|
26
|
+
];
|
|
27
|
+
|
|
28
|
+
export const PageControlExample: ComponentExample<PageControlProps> = {
|
|
29
|
+
containerStyle: { width: '100%' },
|
|
30
|
+
defaultState: {},
|
|
31
|
+
disableProps: [],
|
|
32
|
+
presets,
|
|
33
|
+
render: ({ props, Component }) => <Component {...props} />,
|
|
34
|
+
sections: [],
|
|
35
|
+
variants: {},
|
|
36
|
+
};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Pagination } from './Pagination';
|
|
2
|
+
import { hasNoBasicA11yIssues } from '-/rtl/hasNoBasicA11yIssues';
|
|
3
|
+
import { render } from '-/rtl/util';
|
|
4
|
+
|
|
5
|
+
const TestBed = () => <Pagination numPages={4} onChange={() => {}} value={1} />;
|
|
6
|
+
|
|
7
|
+
describe('Pagination (RTL)', () => {
|
|
8
|
+
it('has no basic a11y issues', hasNoBasicA11yIssues(<TestBed />));
|
|
9
|
+
|
|
10
|
+
it('renders', () => {
|
|
11
|
+
const { getByText } = render(<TestBed />);
|
|
12
|
+
|
|
13
|
+
expect(getByText('First page')).toBeInTheDocument();
|
|
14
|
+
});
|
|
15
|
+
});
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import { SvgIcon } from '@bspk/icons/SvgIcon';
|
|
2
|
-
|
|
3
1
|
import './pagination.scss';
|
|
2
|
+
import { SvgIcon } from '@bspk/icons/SvgIcon';
|
|
4
3
|
import { AriaAttributes } from 'react';
|
|
5
4
|
import { PageInput } from './PageInput';
|
|
6
5
|
import { PageList } from './PageList';
|
|
@@ -40,11 +39,7 @@ export type PaginationProps = {
|
|
|
40
39
|
*
|
|
41
40
|
* const { currentPage, setCurrentPage } = usePaginationState(numPages);
|
|
42
41
|
*
|
|
43
|
-
* return
|
|
44
|
-
* <Pagination value={currentPage} onChange={setCurrentPage} numPages={numPages}>
|
|
45
|
-
* Example Pagination
|
|
46
|
-
* </Pagination>
|
|
47
|
-
* );
|
|
42
|
+
* return <Pagination value={currentPage} onChange={setCurrentPage} numPages={numPages} />;
|
|
48
43
|
* }
|
|
49
44
|
*
|
|
50
45
|
* @name Pagination
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { PasswordField } from './PasswordField';
|
|
2
|
+
import { hasNoBasicA11yIssues } from '-/rtl/hasNoBasicA11yIssues';
|
|
3
|
+
import { render } from '-/rtl/util';
|
|
4
|
+
|
|
5
|
+
const TestBed = () => (
|
|
6
|
+
<PasswordField
|
|
7
|
+
aria-label="Password field"
|
|
8
|
+
controlId="Example controlId"
|
|
9
|
+
label="Password field"
|
|
10
|
+
name="Example name"
|
|
11
|
+
onChange={() => {}}
|
|
12
|
+
value="foo"
|
|
13
|
+
/>
|
|
14
|
+
);
|
|
15
|
+
|
|
16
|
+
describe('PasswordField (RTL)', () => {
|
|
17
|
+
it('has no basic a11y issues', hasNoBasicA11yIssues(<TestBed />));
|
|
18
|
+
|
|
19
|
+
it('renders', () => {
|
|
20
|
+
const { getByLabelText } = render(<TestBed />);
|
|
21
|
+
|
|
22
|
+
expect(getByLabelText('Password field')).toBeInTheDocument();
|
|
23
|
+
});
|
|
24
|
+
});
|
|
@@ -27,7 +27,7 @@ export type PasswordFieldProps = FormFieldWrapProps<PasswordInputProps>;
|
|
|
27
27
|
* }
|
|
28
28
|
*
|
|
29
29
|
* @name PasswordField
|
|
30
|
-
* @phase
|
|
30
|
+
* @phase UXReview
|
|
31
31
|
*/
|
|
32
32
|
export function PasswordField({
|
|
33
33
|
controlId,
|
|
@@ -37,7 +37,7 @@ export function PasswordField({
|
|
|
37
37
|
label,
|
|
38
38
|
labelTrailing,
|
|
39
39
|
required,
|
|
40
|
-
...
|
|
40
|
+
...passwordInputProps
|
|
41
41
|
}: PasswordFieldProps) {
|
|
42
42
|
return (
|
|
43
43
|
<FormField
|
|
@@ -52,13 +52,12 @@ export function PasswordField({
|
|
|
52
52
|
>
|
|
53
53
|
{(fieldProps) => (
|
|
54
54
|
<PasswordInput
|
|
55
|
-
{...
|
|
55
|
+
{...passwordInputProps}
|
|
56
56
|
{...fieldProps}
|
|
57
|
-
aria-label={label}
|
|
58
57
|
id={controlId}
|
|
59
58
|
invalid={invalid}
|
|
60
59
|
required={required}
|
|
61
|
-
value={
|
|
60
|
+
value={passwordInputProps.value ?? ''}
|
|
62
61
|
/>
|
|
63
62
|
)}
|
|
64
63
|
</FormField>
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { PasswordInput } from './PasswordInput';
|
|
2
|
+
import { hasNoBasicA11yIssues } from '-/rtl/hasNoBasicA11yIssues';
|
|
3
|
+
import { render } from '-/rtl/util';
|
|
4
|
+
|
|
5
|
+
const TestBed = () => <PasswordInput aria-label="Password field" name="Example name" onChange={() => {}} value="foo" />;
|
|
6
|
+
|
|
7
|
+
describe('PasswordInput (RTL)', () => {
|
|
8
|
+
it('has no basic a11y issues', hasNoBasicA11yIssues(<TestBed />));
|
|
9
|
+
|
|
10
|
+
it('renders', () => {
|
|
11
|
+
const { getByLabelText } = render(<TestBed />);
|
|
12
|
+
|
|
13
|
+
expect(getByLabelText('Password field')).toBeInTheDocument();
|
|
14
|
+
});
|
|
15
|
+
});
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { useState } from 'react';
|
|
2
1
|
import './password-input.scss';
|
|
2
|
+
import { useState } from 'react';
|
|
3
3
|
import { Button } from '-/components/Button';
|
|
4
4
|
import { TextInput, TextInputProps } from '-/components/TextInput';
|
|
5
5
|
|
|
@@ -36,7 +36,7 @@ export type PasswordInputProps = Pick<
|
|
|
36
36
|
* }
|
|
37
37
|
*
|
|
38
38
|
* @name PasswordInput
|
|
39
|
-
* @phase
|
|
39
|
+
* @phase UXReview
|
|
40
40
|
*/
|
|
41
41
|
export function PasswordInput({
|
|
42
42
|
disabled,
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { PhoneNumberField } from './PhoneNumberField';
|
|
2
|
+
import { hasNoBasicA11yIssues } from '-/rtl/hasNoBasicA11yIssues';
|
|
3
|
+
import { render } from '-/rtl/util';
|
|
4
|
+
|
|
5
|
+
const TestBed = () => (
|
|
6
|
+
<PhoneNumberField
|
|
7
|
+
aria-label="Phone number field"
|
|
8
|
+
controlId="Example controlId"
|
|
9
|
+
label="Phone number field"
|
|
10
|
+
name="Example name"
|
|
11
|
+
onChange={() => {}}
|
|
12
|
+
value="9375551060"
|
|
13
|
+
/>
|
|
14
|
+
);
|
|
15
|
+
|
|
16
|
+
describe('PhoneNumberField (RTL)', () => {
|
|
17
|
+
it('has no basic a11y issues', hasNoBasicA11yIssues(<TestBed />));
|
|
18
|
+
|
|
19
|
+
it('renders', () => {
|
|
20
|
+
const { getByLabelText } = render(<TestBed />);
|
|
21
|
+
|
|
22
|
+
expect(getByLabelText('Phone number field')).toBeInTheDocument();
|
|
23
|
+
});
|
|
24
|
+
});
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { PhoneNumberInput } from './PhoneNumberInput';
|
|
2
|
+
import { hasNoBasicA11yIssues } from '-/rtl/hasNoBasicA11yIssues';
|
|
3
|
+
import { render } from '-/rtl/util';
|
|
4
|
+
|
|
5
|
+
const TestBed = () => (
|
|
6
|
+
<PhoneNumberInput aria-label="Phone number input" name="Example name" onChange={() => {}} value="9375551060" />
|
|
7
|
+
);
|
|
8
|
+
|
|
9
|
+
describe('PhoneNumberInput (RTL)', () => {
|
|
10
|
+
it('has no basic a11y issues', hasNoBasicA11yIssues(<TestBed />));
|
|
11
|
+
|
|
12
|
+
it('renders', () => {
|
|
13
|
+
const { getByLabelText } = render(<TestBed />);
|
|
14
|
+
|
|
15
|
+
expect(getByLabelText('Phone number input')).toBeInTheDocument();
|
|
16
|
+
});
|
|
17
|
+
});
|