@lumx/react 3.1.0 → 3.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/{dist/CONTRIBUTING.md → CONTRIBUTING.md} +0 -0
- package/{dist/LICENSE.md → LICENSE.md} +0 -0
- package/{dist/_internal → _internal}/ClickAwayProvider.js +0 -0
- package/{dist/_internal → _internal}/ClickAwayProvider.js.map +0 -0
- package/{dist/_internal → _internal}/types.d.ts +0 -0
- package/{dist/index.d.ts → index.d.ts} +0 -0
- package/{dist/index.js → index.js} +0 -0
- package/{dist/index.js.map → index.js.map} +0 -0
- package/package.json +3 -3
- package/{dist/utils → utils}/index.d.ts +0 -0
- package/{dist/utils → utils}/index.js +0 -0
- package/{dist/utils → utils}/index.js.map +0 -0
- package/dist/README.md +0 -38
- package/dist/package.json +0 -117
- package/dist/src/components/alert-dialog/AlertDialog.stories.tsx +0 -196
- package/dist/src/components/alert-dialog/AlertDialog.test.tsx +0 -43
- package/dist/src/components/alert-dialog/AlertDialog.tsx +0 -185
- package/dist/src/components/alert-dialog/__snapshots__/AlertDialog.test.tsx.snap +0 -551
- package/dist/src/components/alert-dialog/index.ts +0 -1
- package/dist/src/components/autocomplete/Autocomplete.stories.tsx +0 -70
- package/dist/src/components/autocomplete/Autocomplete.test.tsx +0 -181
- package/dist/src/components/autocomplete/Autocomplete.tsx +0 -292
- package/dist/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -170
- package/dist/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -94
- package/dist/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
- package/dist/src/components/autocomplete/__mockData__/index.ts +0 -34
- package/dist/src/components/autocomplete/__snapshots__/Autocomplete.test.tsx.snap +0 -213
- package/dist/src/components/autocomplete/__snapshots__/AutocompleteMultiple.test.tsx.snap +0 -88
- package/dist/src/components/autocomplete/index.ts +0 -2
- package/dist/src/components/avatar/Avatar.stories.tsx +0 -92
- package/dist/src/components/avatar/Avatar.test.tsx +0 -39
- package/dist/src/components/avatar/Avatar.tsx +0 -112
- package/dist/src/components/avatar/__snapshots__/Avatar.test.tsx.snap +0 -681
- package/dist/src/components/avatar/index.ts +0 -1
- package/dist/src/components/badge/Badge.stories.tsx +0 -45
- package/dist/src/components/badge/Badge.test.tsx +0 -91
- package/dist/src/components/badge/Badge.tsx +0 -55
- package/dist/src/components/badge/__snapshots__/Badge.test.tsx.snap +0 -11
- package/dist/src/components/badge/index.ts +0 -1
- package/dist/src/components/button/Button.stories.tsx +0 -156
- package/dist/src/components/button/Button.test.tsx +0 -152
- package/dist/src/components/button/Button.tsx +0 -81
- package/dist/src/components/button/ButtonGroup.test.tsx +0 -66
- package/dist/src/components/button/ButtonGroup.tsx +0 -46
- package/dist/src/components/button/ButtonRoot.test.tsx +0 -203
- package/dist/src/components/button/ButtonRoot.tsx +0 -190
- package/dist/src/components/button/IconButton.test.tsx +0 -103
- package/dist/src/components/button/IconButton.tsx +0 -80
- package/dist/src/components/button/__snapshots__/Button.test.tsx.snap +0 -96
- package/dist/src/components/button/__snapshots__/ButtonGroup.test.tsx.snap +0 -22
- package/dist/src/components/button/__snapshots__/ButtonRoot.test.tsx.snap +0 -160
- package/dist/src/components/button/__snapshots__/IconButton.test.tsx.snap +0 -83
- package/dist/src/components/button/index.ts +0 -4
- package/dist/src/components/checkbox/Checkbox.stories.tsx +0 -37
- package/dist/src/components/checkbox/Checkbox.test.tsx +0 -114
- package/dist/src/components/checkbox/Checkbox.tsx +0 -145
- package/dist/src/components/checkbox/__snapshots__/Checkbox.test.tsx.snap +0 -141
- package/dist/src/components/checkbox/index.ts +0 -1
- package/dist/src/components/chip/Chip.stories.tsx +0 -21
- package/dist/src/components/chip/Chip.test.tsx +0 -199
- package/dist/src/components/chip/Chip.tsx +0 -154
- package/dist/src/components/chip/ChipGroup.test.tsx +0 -29
- package/dist/src/components/chip/ChipGroup.tsx +0 -62
- package/dist/src/components/chip/__snapshots__/Chip.test.tsx.snap +0 -12
- package/dist/src/components/chip/__snapshots__/ChipGroup.test.tsx.snap +0 -29
- package/dist/src/components/chip/index.ts +0 -2
- package/dist/src/components/comment-block/CommentBlock.stories.tsx +0 -30
- package/dist/src/components/comment-block/CommentBlock.test.tsx +0 -28
- package/dist/src/components/comment-block/CommentBlock.tsx +0 -174
- package/dist/src/components/comment-block/__snapshots__/CommentBlock.test.tsx.snap +0 -92
- package/dist/src/components/comment-block/index.ts +0 -1
- package/dist/src/components/date-picker/DatePicker.test.tsx +0 -41
- package/dist/src/components/date-picker/DatePicker.tsx +0 -56
- package/dist/src/components/date-picker/DatePickerControlled.test.tsx +0 -44
- package/dist/src/components/date-picker/DatePickerControlled.tsx +0 -128
- package/dist/src/components/date-picker/DatePickerField.stories.tsx +0 -93
- package/dist/src/components/date-picker/DatePickerField.test.tsx +0 -47
- package/dist/src/components/date-picker/DatePickerField.tsx +0 -141
- package/dist/src/components/date-picker/__snapshots__/DatePicker.test.tsx.snap +0 -22
- package/dist/src/components/date-picker/__snapshots__/DatePickerControlled.test.tsx.snap +0 -597
- package/dist/src/components/date-picker/__snapshots__/DatePickerField.test.tsx.snap +0 -43
- package/dist/src/components/date-picker/constants.ts +0 -11
- package/dist/src/components/date-picker/index.ts +0 -4
- package/dist/src/components/date-picker/types.ts +0 -28
- package/dist/src/components/dialog/Dialog.stories.tsx +0 -426
- package/dist/src/components/dialog/Dialog.test.tsx +0 -93
- package/dist/src/components/dialog/Dialog.tsx +0 -263
- package/dist/src/components/dialog/__snapshots__/Dialog.test.tsx.snap +0 -960
- package/dist/src/components/dialog/index.ts +0 -1
- package/dist/src/components/divider/Divider.test.tsx +0 -93
- package/dist/src/components/divider/Divider.tsx +0 -51
- package/dist/src/components/divider/__snapshots__/Divider.test.tsx.snap +0 -9
- package/dist/src/components/divider/index.ts +0 -1
- package/dist/src/components/drag-handle/DragHandle.tsx +0 -50
- package/dist/src/components/drag-handle/index.ts +0 -1
- package/dist/src/components/dropdown/Dropdown.stories.tsx +0 -216
- package/dist/src/components/dropdown/Dropdown.test.tsx +0 -97
- package/dist/src/components/dropdown/Dropdown.tsx +0 -184
- package/dist/src/components/dropdown/__snapshots__/Dropdown.test.tsx.snap +0 -35
- package/dist/src/components/dropdown/index.ts +0 -1
- package/dist/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -116
- package/dist/src/components/expansion-panel/ExpansionPanel.tsx +0 -170
- package/dist/src/components/expansion-panel/index.ts +0 -1
- package/dist/src/components/flag/Flag.stories.tsx +0 -23
- package/dist/src/components/flag/Flag.test.tsx +0 -86
- package/dist/src/components/flag/Flag.tsx +0 -47
- package/dist/src/components/flag/__snapshots__/Flag.test.tsx.snap +0 -133
- package/dist/src/components/flag/index.ts +0 -1
- package/dist/src/components/flex-box/FlexBox.stories.tsx +0 -245
- package/dist/src/components/flex-box/FlexBox.test.tsx +0 -65
- package/dist/src/components/flex-box/FlexBox.tsx +0 -98
- package/dist/src/components/flex-box/__snapshots__/FlexBox.test.tsx.snap +0 -492
- package/dist/src/components/flex-box/index.ts +0 -1
- package/dist/src/components/generic-block/GenericBlock.stories.jsx +0 -128
- package/dist/src/components/generic-block/GenericBlock.test.tsx +0 -152
- package/dist/src/components/generic-block/GenericBlock.tsx +0 -222
- package/dist/src/components/generic-block/constants.ts +0 -9
- package/dist/src/components/generic-block/index.ts +0 -2
- package/dist/src/components/grid/Grid.tsx +0 -73
- package/dist/src/components/grid/GridItem.tsx +0 -54
- package/dist/src/components/grid/index.ts +0 -2
- package/dist/src/components/grid-column/GridColumn.stories.jsx +0 -56
- package/dist/src/components/grid-column/GridColumn.test.jsx +0 -58
- package/dist/src/components/grid-column/GridColumn.tsx +0 -90
- package/dist/src/components/grid-column/index.ts +0 -1
- package/dist/src/components/heading/Heading.stories.tsx +0 -108
- package/dist/src/components/heading/Heading.test.tsx +0 -82
- package/dist/src/components/heading/Heading.tsx +0 -63
- package/dist/src/components/heading/HeadingLevelProvider.tsx +0 -30
- package/dist/src/components/heading/constants.ts +0 -16
- package/dist/src/components/heading/context.tsx +0 -13
- package/dist/src/components/heading/index.ts +0 -3
- package/dist/src/components/heading/useHeadingLevel.tsx +0 -8
- package/dist/src/components/icon/Icon.stories.tsx +0 -76
- package/dist/src/components/icon/Icon.test.tsx +0 -102
- package/dist/src/components/icon/Icon.tsx +0 -121
- package/dist/src/components/icon/__snapshots__/Icon.test.tsx.snap +0 -49
- package/dist/src/components/icon/index.ts +0 -1
- package/dist/src/components/image-block/ImageBlock.stories.tsx +0 -52
- package/dist/src/components/image-block/ImageBlock.test.tsx +0 -28
- package/dist/src/components/image-block/ImageBlock.tsx +0 -151
- package/dist/src/components/image-block/__snapshots__/ImageBlock.test.tsx.snap +0 -64
- package/dist/src/components/image-block/index.ts +0 -1
- package/dist/src/components/index.ts +0 -176
- package/dist/src/components/inline-list/InlineList.stories.tsx +0 -40
- package/dist/src/components/inline-list/InlineList.test.tsx +0 -41
- package/dist/src/components/inline-list/InlineList.tsx +0 -82
- package/dist/src/components/inline-list/index.ts +0 -1
- package/dist/src/components/input-helper/InputHelper.stories.tsx +0 -29
- package/dist/src/components/input-helper/InputHelper.test.tsx +0 -107
- package/dist/src/components/input-helper/InputHelper.tsx +0 -61
- package/dist/src/components/input-helper/__snapshots__/InputHelper.test.tsx.snap +0 -9
- package/dist/src/components/input-helper/constants.ts +0 -11
- package/dist/src/components/input-helper/index.ts +0 -1
- package/dist/src/components/input-label/InputLabel.stories.tsx +0 -15
- package/dist/src/components/input-label/InputLabel.test.tsx +0 -86
- package/dist/src/components/input-label/InputLabel.tsx +0 -59
- package/dist/src/components/input-label/__snapshots__/InputLabel.test.tsx.snap +0 -10
- package/dist/src/components/input-label/index.ts +0 -1
- package/dist/src/components/lightbox/Lightbox.stories.tsx +0 -83
- package/dist/src/components/lightbox/Lightbox.test.tsx +0 -30
- package/dist/src/components/lightbox/Lightbox.tsx +0 -153
- package/dist/src/components/lightbox/__snapshots__/Lightbox.test.tsx.snap +0 -194
- package/dist/src/components/lightbox/index.ts +0 -1
- package/dist/src/components/link/Link.stories.tsx +0 -141
- package/dist/src/components/link/Link.test.tsx +0 -60
- package/dist/src/components/link/Link.tsx +0 -156
- package/dist/src/components/link/__snapshots__/Link.test.tsx.snap +0 -29
- package/dist/src/components/link/index.ts +0 -1
- package/dist/src/components/link-preview/LinkPreview.stories.tsx +0 -88
- package/dist/src/components/link-preview/LinkPreview.test.tsx +0 -102
- package/dist/src/components/link-preview/LinkPreview.tsx +0 -158
- package/dist/src/components/link-preview/index.ts +0 -1
- package/dist/src/components/list/List.stories.tsx +0 -141
- package/dist/src/components/list/List.test.tsx +0 -29
- package/dist/src/components/list/List.tsx +0 -94
- package/dist/src/components/list/ListDivider.stories.tsx +0 -7
- package/dist/src/components/list/ListDivider.test.tsx +0 -29
- package/dist/src/components/list/ListDivider.tsx +0 -42
- package/dist/src/components/list/ListItem.stories.tsx +0 -62
- package/dist/src/components/list/ListItem.test.tsx +0 -29
- package/dist/src/components/list/ListItem.tsx +0 -154
- package/dist/src/components/list/ListSubheader.stories.tsx +0 -8
- package/dist/src/components/list/ListSubheader.test.tsx +0 -29
- package/dist/src/components/list/ListSubheader.tsx +0 -43
- package/dist/src/components/list/__snapshots__/List.test.tsx.snap +0 -360
- package/dist/src/components/list/__snapshots__/ListDivider.test.tsx.snap +0 -7
- package/dist/src/components/list/__snapshots__/ListItem.test.tsx.snap +0 -160
- package/dist/src/components/list/__snapshots__/ListSubheader.test.tsx.snap +0 -9
- package/dist/src/components/list/index.ts +0 -4
- package/dist/src/components/list/useInteractiveList.tsx +0 -202
- package/dist/src/components/message/Message.stories.tsx +0 -27
- package/dist/src/components/message/Message.test.tsx +0 -76
- package/dist/src/components/message/Message.tsx +0 -74
- package/dist/src/components/message/__snapshots__/Message.test.tsx.snap +0 -15
- package/dist/src/components/message/index.ts +0 -1
- package/dist/src/components/mosaic/Mosaic.stories.tsx +0 -85
- package/dist/src/components/mosaic/Mosaic.test.tsx +0 -120
- package/dist/src/components/mosaic/Mosaic.tsx +0 -95
- package/dist/src/components/mosaic/__snapshots__/Mosaic.test.tsx.snap +0 -357
- package/dist/src/components/mosaic/index.ts +0 -1
- package/dist/src/components/notification/Notification.test.tsx +0 -108
- package/dist/src/components/notification/Notification.tsx +0 -130
- package/dist/src/components/notification/Notifications.stories.tsx +0 -77
- package/dist/src/components/notification/__snapshots__/Notification.test.tsx.snap +0 -34
- package/dist/src/components/notification/constants.ts +0 -28
- package/dist/src/components/notification/index.ts +0 -1
- package/dist/src/components/popover/Popover.stories.tsx +0 -386
- package/dist/src/components/popover/Popover.test.tsx +0 -30
- package/dist/src/components/popover/Popover.tsx +0 -382
- package/dist/src/components/popover/__snapshots__/Popover.test.tsx.snap +0 -343
- package/dist/src/components/popover/index.ts +0 -1
- package/dist/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -75
- package/dist/src/components/popover-dialog/PopoverDialog.test.tsx +0 -65
- package/dist/src/components/popover-dialog/PopoverDialog.tsx +0 -65
- package/dist/src/components/popover-dialog/index.tsx +0 -1
- package/dist/src/components/post-block/PostBlock.test.tsx +0 -28
- package/dist/src/components/post-block/PostBlock.tsx +0 -123
- package/dist/src/components/post-block/__snapshots__/PostBlock.test.tsx.snap +0 -139
- package/dist/src/components/post-block/index.ts +0 -1
- package/dist/src/components/progress/Progress.tsx +0 -68
- package/dist/src/components/progress/ProgressCircular.stories.tsx +0 -18
- package/dist/src/components/progress/ProgressCircular.test.tsx +0 -49
- package/dist/src/components/progress/ProgressCircular.tsx +0 -68
- package/dist/src/components/progress/ProgressLinear.stories.tsx +0 -8
- package/dist/src/components/progress/ProgressLinear.test.tsx +0 -37
- package/dist/src/components/progress/ProgressLinear.tsx +0 -52
- package/dist/src/components/progress/index.ts +0 -3
- package/dist/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
- package/dist/src/components/progress-tracker/ProgressTracker.test.tsx +0 -57
- package/dist/src/components/progress-tracker/ProgressTracker.tsx +0 -89
- package/dist/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -42
- package/dist/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -66
- package/dist/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -128
- package/dist/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
- package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -73
- package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -67
- package/dist/src/components/progress-tracker/__snapshots__/ProgressTracker.test.tsx.snap +0 -41
- package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStep.test.tsx.snap +0 -141
- package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStepPanel.test.tsx.snap +0 -25
- package/dist/src/components/progress-tracker/index.ts +0 -4
- package/dist/src/components/radio-button/RadioButton.stories.tsx +0 -28
- package/dist/src/components/radio-button/RadioButton.test.tsx +0 -123
- package/dist/src/components/radio-button/RadioButton.tsx +0 -141
- package/dist/src/components/radio-button/RadioGroup.stories.tsx +0 -42
- package/dist/src/components/radio-button/RadioGroup.test.tsx +0 -77
- package/dist/src/components/radio-button/RadioGroup.tsx +0 -52
- package/dist/src/components/radio-button/__snapshots__/RadioButton.test.tsx.snap +0 -113
- package/dist/src/components/radio-button/__snapshots__/RadioGroup.test.tsx.snap +0 -26
- package/dist/src/components/radio-button/index.ts +0 -2
- package/dist/src/components/select/Select.stories.tsx +0 -399
- package/dist/src/components/select/Select.test.tsx +0 -359
- package/dist/src/components/select/Select.tsx +0 -193
- package/dist/src/components/select/SelectMultiple.stories.tsx +0 -227
- package/dist/src/components/select/SelectMultiple.test.tsx +0 -405
- package/dist/src/components/select/SelectMultiple.tsx +0 -198
- package/dist/src/components/select/WithSelectContext.tsx +0 -143
- package/dist/src/components/select/__snapshots__/Select.test.tsx.snap +0 -43
- package/dist/src/components/select/__snapshots__/SelectMultiple.test.tsx.snap +0 -87
- package/dist/src/components/select/constants.ts +0 -53
- package/dist/src/components/select/index.ts +0 -2
- package/dist/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
- package/dist/src/components/side-navigation/SideNavigation.test.tsx +0 -52
- package/dist/src/components/side-navigation/SideNavigation.tsx +0 -54
- package/dist/src/components/side-navigation/SideNavigationItem.test.tsx +0 -175
- package/dist/src/components/side-navigation/SideNavigationItem.tsx +0 -162
- package/dist/src/components/side-navigation/__snapshots__/SideNavigation.test.tsx.snap +0 -7
- package/dist/src/components/side-navigation/__snapshots__/SideNavigationItem.test.tsx.snap +0 -30
- package/dist/src/components/side-navigation/index.ts +0 -2
- package/dist/src/components/skeleton/SkeletonCircle.stories.tsx +0 -25
- package/dist/src/components/skeleton/SkeletonCircle.test.tsx +0 -28
- package/dist/src/components/skeleton/SkeletonCircle.tsx +0 -52
- package/dist/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -107
- package/dist/src/components/skeleton/SkeletonRectangle.test.tsx +0 -28
- package/dist/src/components/skeleton/SkeletonRectangle.tsx +0 -78
- package/dist/src/components/skeleton/SkeletonTypography.stories.tsx +0 -26
- package/dist/src/components/skeleton/SkeletonTypography.test.tsx +0 -28
- package/dist/src/components/skeleton/SkeletonTypography.tsx +0 -57
- package/dist/src/components/skeleton/__snapshots__/SkeletonCircle.test.tsx.snap +0 -54
- package/dist/src/components/skeleton/__snapshots__/SkeletonRectangle.test.tsx.snap +0 -177
- package/dist/src/components/skeleton/__snapshots__/SkeletonTypography.test.tsx.snap +0 -174
- package/dist/src/components/skeleton/index.ts +0 -3
- package/dist/src/components/slider/Slider.stories.tsx +0 -29
- package/dist/src/components/slider/Slider.test.tsx +0 -31
- package/dist/src/components/slider/Slider.tsx +0 -299
- package/dist/src/components/slider/__snapshots__/Slider.test.tsx.snap +0 -122
- package/dist/src/components/slider/index.ts +0 -2
- package/dist/src/components/slideshow/Slides.tsx +0 -124
- package/dist/src/components/slideshow/Slideshow.stories.tsx +0 -212
- package/dist/src/components/slideshow/Slideshow.test.tsx +0 -39
- package/dist/src/components/slideshow/Slideshow.tsx +0 -170
- package/dist/src/components/slideshow/SlideshowControls.stories.tsx +0 -112
- package/dist/src/components/slideshow/SlideshowControls.tsx +0 -241
- package/dist/src/components/slideshow/SlideshowItem.tsx +0 -52
- package/dist/src/components/slideshow/SlideshowItemGroup.tsx +0 -64
- package/dist/src/components/slideshow/__snapshots__/Slideshow.test.tsx.snap +0 -157
- package/dist/src/components/slideshow/constants.ts +0 -24
- package/dist/src/components/slideshow/index.ts +0 -4
- package/dist/src/components/slideshow/useKeyNavigate.ts +0 -28
- package/dist/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
- package/dist/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
- package/dist/src/components/slideshow/useSwipeNavigate.ts +0 -18
- package/dist/src/components/switch/Switch.stories.tsx +0 -36
- package/dist/src/components/switch/Switch.test.tsx +0 -189
- package/dist/src/components/switch/Switch.tsx +0 -141
- package/dist/src/components/switch/__snapshots__/Switch.test.tsx.snap +0 -179
- package/dist/src/components/switch/index.ts +0 -1
- package/dist/src/components/table/Table.test.tsx +0 -28
- package/dist/src/components/table/Table.tsx +0 -59
- package/dist/src/components/table/TableBody.test.tsx +0 -22
- package/dist/src/components/table/TableBody.tsx +0 -44
- package/dist/src/components/table/TableCell.test.tsx +0 -23
- package/dist/src/components/table/TableCell.tsx +0 -125
- package/dist/src/components/table/TableHeader.test.tsx +0 -22
- package/dist/src/components/table/TableHeader.tsx +0 -50
- package/dist/src/components/table/TableRow.test.tsx +0 -22
- package/dist/src/components/table/TableRow.tsx +0 -68
- package/dist/src/components/table/__snapshots__/Table.test.tsx.snap +0 -263
- package/dist/src/components/table/index.ts +0 -5
- package/dist/src/components/tabs/Tab.test.tsx +0 -116
- package/dist/src/components/tabs/Tab.tsx +0 -120
- package/dist/src/components/tabs/TabList.test.tsx +0 -80
- package/dist/src/components/tabs/TabList.tsx +0 -82
- package/dist/src/components/tabs/TabPanel.test.tsx +0 -74
- package/dist/src/components/tabs/TabPanel.tsx +0 -65
- package/dist/src/components/tabs/TabProvider.test.tsx +0 -42
- package/dist/src/components/tabs/TabProvider.tsx +0 -59
- package/dist/src/components/tabs/Tabs.stories.tsx +0 -134
- package/dist/src/components/tabs/__snapshots__/Tab.test.tsx.snap +0 -62
- package/dist/src/components/tabs/__snapshots__/TabList.test.tsx.snap +0 -22
- package/dist/src/components/tabs/__snapshots__/TabPanel.test.tsx.snap +0 -25
- package/dist/src/components/tabs/index.ts +0 -4
- package/dist/src/components/tabs/state.ts +0 -116
- package/dist/src/components/tabs/test.mocks.ts +0 -33
- package/dist/src/components/text/Text.stories.jsx +0 -75
- package/dist/src/components/text/Text.test.tsx +0 -108
- package/dist/src/components/text/Text.tsx +0 -121
- package/dist/src/components/text/index.ts +0 -1
- package/dist/src/components/text-field/TextField.stories.tsx +0 -169
- package/dist/src/components/text-field/TextField.test.tsx +0 -171
- package/dist/src/components/text-field/TextField.tsx +0 -432
- package/dist/src/components/text-field/__snapshots__/TextField.test.tsx.snap +0 -42
- package/dist/src/components/text-field/index.ts +0 -1
- package/dist/src/components/thumbnail/Thumbnail.stories.tsx +0 -510
- package/dist/src/components/thumbnail/Thumbnail.test.tsx +0 -46
- package/dist/src/components/thumbnail/Thumbnail.tsx +0 -222
- package/dist/src/components/thumbnail/__snapshots__/Thumbnail.test.tsx.snap +0 -130
- package/dist/src/components/thumbnail/index.ts +0 -3
- package/dist/src/components/thumbnail/types.ts +0 -39
- package/dist/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
- package/dist/src/components/thumbnail/useFocusPointStyle.tsx +0 -111
- package/dist/src/components/thumbnail/useImageLoad.ts +0 -40
- package/dist/src/components/toolbar/Toolbar.tsx +0 -67
- package/dist/src/components/toolbar/index.ts +0 -1
- package/dist/src/components/tooltip/Tooltip.stories.tsx +0 -172
- package/dist/src/components/tooltip/Tooltip.test.tsx +0 -105
- package/dist/src/components/tooltip/Tooltip.tsx +0 -122
- package/dist/src/components/tooltip/__snapshots__/Tooltip.test.tsx.snap +0 -233
- package/dist/src/components/tooltip/index.ts +0 -1
- package/dist/src/components/tooltip/useInjectTooltipRef.tsx +0 -44
- package/dist/src/components/tooltip/useTooltipOpen.tsx +0 -113
- package/dist/src/components/uploader/Uploader.test.tsx +0 -87
- package/dist/src/components/uploader/Uploader.tsx +0 -105
- package/dist/src/components/uploader/__snapshots__/Uploader.test.tsx.snap +0 -14
- package/dist/src/components/uploader/index.ts +0 -1
- package/dist/src/components/user-block/UserBlock.stories.tsx +0 -76
- package/dist/src/components/user-block/UserBlock.test.tsx +0 -38
- package/dist/src/components/user-block/UserBlock.tsx +0 -179
- package/dist/src/components/user-block/__snapshots__/UserBlock.test.tsx.snap +0 -362
- package/dist/src/components/user-block/index.ts +0 -1
- package/dist/src/constants.ts +0 -17
- package/dist/src/hooks/useBooleanState.tsx +0 -13
- package/dist/src/hooks/useCallbackOnEscape.ts +0 -34
- package/dist/src/hooks/useChipGroupNavigation.tsx +0 -75
- package/dist/src/hooks/useClickAway.tsx +0 -47
- package/dist/src/hooks/useDisableBodyScroll.ts +0 -28
- package/dist/src/hooks/useEventCallback.tsx +0 -17
- package/dist/src/hooks/useFocus.tsx +0 -21
- package/dist/src/hooks/useFocusTrap.ts +0 -85
- package/dist/src/hooks/useFocusWithin.ts +0 -33
- package/dist/src/hooks/useInfiniteScroll.tsx +0 -60
- package/dist/src/hooks/useIntersectionObserver.tsx +0 -43
- package/dist/src/hooks/useInterval.tsx +0 -31
- package/dist/src/hooks/useKeyboardListNavigation.tsx +0 -204
- package/dist/src/hooks/useListenFocus.tsx +0 -26
- package/dist/src/hooks/useOnResize.ts +0 -41
- package/dist/src/hooks/useRovingTabIndex.tsx +0 -90
- package/dist/src/hooks/useSlideshowControls.ts +0 -243
- package/dist/src/hooks/useStopPropagation.ts +0 -21
- package/dist/src/hooks/useTransitionVisibility.ts +0 -54
- package/dist/src/index.ts +0 -58
- package/dist/src/stories/chromaticForceScreenSize.tsx +0 -7
- package/dist/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
- package/dist/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
- package/dist/src/stories/generated/Badge/Demos.stories.tsx +0 -9
- package/dist/src/stories/generated/Button/Demos.stories.tsx +0 -11
- package/dist/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
- package/dist/src/stories/generated/Chip/Demos.stories.tsx +0 -11
- package/dist/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
- package/dist/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
- package/dist/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
- package/dist/src/stories/generated/Divider/Demos.stories.tsx +0 -6
- package/dist/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
- package/dist/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
- package/dist/src/stories/generated/Flag/Demos.stories.tsx +0 -6
- package/dist/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
- package/dist/src/stories/generated/Heading/Demos.stories.tsx +0 -6
- package/dist/src/stories/generated/Icon/Demos.stories.tsx +0 -8
- package/dist/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
- package/dist/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
- package/dist/src/stories/generated/Link/Demos.stories.tsx +0 -8
- package/dist/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
- package/dist/src/stories/generated/List/Demos.stories.tsx +0 -11
- package/dist/src/stories/generated/Message/Demos.stories.tsx +0 -10
- package/dist/src/stories/generated/Mosaic/Demos.stories.tsx +0 -9
- package/dist/src/stories/generated/Notification/Demos.stories.tsx +0 -6
- package/dist/src/stories/generated/Popover/Demos.stories.tsx +0 -11
- package/dist/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
- package/dist/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
- package/dist/src/stories/generated/Progress/Demos.stories.tsx +0 -7
- package/dist/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
- package/dist/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
- package/dist/src/stories/generated/Select/Demos.stories.tsx +0 -14
- package/dist/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
- package/dist/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
- package/dist/src/stories/generated/Slider/Demos.stories.tsx +0 -9
- package/dist/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
- package/dist/src/stories/generated/Switch/Demos.stories.tsx +0 -6
- package/dist/src/stories/generated/Table/Demos.stories.tsx +0 -6
- package/dist/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
- package/dist/src/stories/generated/TextField/Demos.stories.tsx +0 -19
- package/dist/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
- package/dist/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
- package/dist/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
- package/dist/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
- package/dist/src/stories/generated/UserBlock/Demos.stories.tsx +0 -10
- package/dist/src/stories/knobs/buttonKnob.ts +0 -9
- package/dist/src/stories/knobs/emphasisKnob.ts +0 -8
- package/dist/src/stories/knobs/enumKnob.ts +0 -14
- package/dist/src/stories/knobs/focusKnob.ts +0 -3
- package/dist/src/stories/knobs/image.ts +0 -69
- package/dist/src/stories/knobs/lorem.ts +0 -59
- package/dist/src/stories/knobs/sizeKnob.ts +0 -5
- package/dist/src/stories/knobs/thumbnailsKnob.ts +0 -9
- package/dist/src/stories/utils/CustomLink.tsx +0 -7
- package/dist/src/stories/withResizableBox.tsx +0 -18
- package/dist/src/testing/utils/commonTestsSuite.ts +0 -71
- package/dist/src/testing/utils/commonTestsSuiteRTL.ts +0 -55
- package/dist/src/testing/utils/index.ts +0 -4
- package/dist/src/testing/utils/itShouldRenderStories.tsx +0 -103
- package/dist/src/testing/utils/queries.ts +0 -19
- package/dist/src/untypped-modules.d.ts +0 -7
- package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -58
- package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -65
- package/dist/src/utils/ClickAwayProvider/index.ts +0 -1
- package/dist/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
- package/dist/src/utils/MaterialThemeSwitcher/index.ts +0 -1
- package/dist/src/utils/browserDoesNotSupportHover.test.js +0 -24
- package/dist/src/utils/browserDoesNotSupportHover.ts +0 -2
- package/dist/src/utils/clamp.ts +0 -17
- package/dist/src/utils/className.ts +0 -44
- package/dist/src/utils/event.ts +0 -1
- package/dist/src/utils/flattenChildren.test.tsx +0 -58
- package/dist/src/utils/flattenChildren.ts +0 -27
- package/dist/src/utils/focus/constants.ts +0 -5
- package/dist/src/utils/focus/getFirstAndLastFocusable.test.ts +0 -134
- package/dist/src/utils/focus/getFirstAndLastFocusable.ts +0 -21
- package/dist/src/utils/focus/getFocusableElements.test.ts +0 -151
- package/dist/src/utils/focus/getFocusableElements.ts +0 -7
- package/dist/src/utils/index.ts +0 -5
- package/dist/src/utils/isInternetExplorer.ts +0 -15
- package/dist/src/utils/makeListenerTowerContext.ts +0 -32
- package/dist/src/utils/mergeRefs.ts +0 -22
- package/dist/src/utils/partitionMulti.ts +0 -28
- package/dist/src/utils/renderLink.tsx +0 -17
- package/dist/src/utils/type.ts +0 -113
- package/dist/src/utils/userHasReducedMotion.ts +0 -7
- package/dist/src/utils/utils.test.ts +0 -48
- package/jest/__mocks__/@storybook/addon-actions.js +0 -3
- package/jest/__mocks__/@storybook/addon-knobs.js +0 -6
- package/jest/__mocks__/emptyFileMockTransformer.js +0 -8
- package/jest/__mocks__/emptyModuleMock.js +0 -1
- package/jest/configure.js +0 -6
- package/jest/index.js +0 -36
- package/jest/transform.js +0 -6
- package/rollup.config.js +0 -98
- package/storybook/build +0 -4
- package/storybook/generate-demo-stories.js +0 -59
- package/storybook/main.js +0 -67
- package/storybook/package.json +0 -13
- package/storybook/preview.js +0 -11
- package/storybook/start +0 -4
- package/storybook/story-block/StoryBlock.tsx +0 -49
- package/storybook/story-block/decorator.jsx +0 -7
- package/storybook/story-block/index.scss +0 -27
- package/storybook/yarn.lock +0 -13192
- package/tsconfig.json +0 -3
|
@@ -1,151 +0,0 @@
|
|
|
1
|
-
import { getFocusableElements } from '@lumx/react/utils/focus/getFocusableElements';
|
|
2
|
-
|
|
3
|
-
function htmlToElement(html: string): any {
|
|
4
|
-
const template = document.createElement('template');
|
|
5
|
-
template.innerHTML = html.trim();
|
|
6
|
-
return template.content.firstChild;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
describe(getFocusableElements.name, () => {
|
|
10
|
-
it('should get empty', () => {
|
|
11
|
-
const element = htmlToElement(`<div></div>`);
|
|
12
|
-
const focusable = getFocusableElements(element);
|
|
13
|
-
expect(focusable).toEqual([]);
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
it('should get single item', () => {
|
|
17
|
-
const element = htmlToElement(`<div><button /></div>`);
|
|
18
|
-
const focusable = getFocusableElements(element);
|
|
19
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
20
|
-
[
|
|
21
|
-
<button />,
|
|
22
|
-
]
|
|
23
|
-
`);
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
describe('match focusable elements', () => {
|
|
27
|
-
it('should match input element', () => {
|
|
28
|
-
const element = htmlToElement(`<div><input /></div>`);
|
|
29
|
-
const focusable = getFocusableElements(element);
|
|
30
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
31
|
-
[
|
|
32
|
-
<input />,
|
|
33
|
-
]
|
|
34
|
-
`);
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
it('should match link element', () => {
|
|
38
|
-
const element = htmlToElement(`<div><a href="#" /></div>`);
|
|
39
|
-
const focusable = getFocusableElements(element);
|
|
40
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
41
|
-
[
|
|
42
|
-
<a
|
|
43
|
-
href="#"
|
|
44
|
-
/>,
|
|
45
|
-
]
|
|
46
|
-
`);
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
it('should match textarea element', () => {
|
|
50
|
-
const element = htmlToElement(`<div><textarea /></div>`);
|
|
51
|
-
const focusable = getFocusableElements(element);
|
|
52
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
53
|
-
[
|
|
54
|
-
<textarea>
|
|
55
|
-
</div>
|
|
56
|
-
</textarea>,
|
|
57
|
-
]
|
|
58
|
-
`);
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
it('should match element with tabindex', () => {
|
|
62
|
-
const element = htmlToElement(`<div><span tabindex="0" /></div>`);
|
|
63
|
-
const focusable = getFocusableElements(element);
|
|
64
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
65
|
-
[
|
|
66
|
-
<span
|
|
67
|
-
tabindex="0"
|
|
68
|
-
/>,
|
|
69
|
-
]
|
|
70
|
-
`);
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
it('should keep disabled=false', () => {
|
|
74
|
-
const element = htmlToElement(`<div><button disabled="false" /><button /></div>`);
|
|
75
|
-
const focusable = getFocusableElements(element);
|
|
76
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
77
|
-
[
|
|
78
|
-
<button
|
|
79
|
-
disabled="false"
|
|
80
|
-
/>,
|
|
81
|
-
<button />,
|
|
82
|
-
]
|
|
83
|
-
`);
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
it('should keep aria-disabled=false', () => {
|
|
87
|
-
const element = htmlToElement(`<div><button aria-disabled="false" /><button /></div>`);
|
|
88
|
-
const focusable = getFocusableElements(element);
|
|
89
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
90
|
-
[
|
|
91
|
-
<button
|
|
92
|
-
aria-disabled="false"
|
|
93
|
-
/>,
|
|
94
|
-
<button />,
|
|
95
|
-
]
|
|
96
|
-
`);
|
|
97
|
-
});
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
describe('skip disabled elements', () => {
|
|
101
|
-
it('should skip disabled', () => {
|
|
102
|
-
const element = htmlToElement(`<div><button disabled /><button /></div>`);
|
|
103
|
-
const focusable = getFocusableElements(element);
|
|
104
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
105
|
-
[
|
|
106
|
-
<button />,
|
|
107
|
-
]
|
|
108
|
-
`);
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
it('should skip aria-disabled', () => {
|
|
112
|
-
const element = htmlToElement(`<div><button aria-disabled /><button /></div>`);
|
|
113
|
-
const focusable = getFocusableElements(element);
|
|
114
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
115
|
-
[
|
|
116
|
-
<button />,
|
|
117
|
-
]
|
|
118
|
-
`);
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
it('should skip tabindex=-1', () => {
|
|
122
|
-
const element = htmlToElement(`<div><button tabindex="-1" /><button /></div>`);
|
|
123
|
-
const focusable = getFocusableElements(element);
|
|
124
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
125
|
-
[
|
|
126
|
-
<button />,
|
|
127
|
-
]
|
|
128
|
-
`);
|
|
129
|
-
});
|
|
130
|
-
|
|
131
|
-
it('should skip input type hidden', () => {
|
|
132
|
-
const element = htmlToElement(`<div><input type="hidden" /><button /></div>`);
|
|
133
|
-
const focusable = getFocusableElements(element);
|
|
134
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
135
|
-
[
|
|
136
|
-
<button />,
|
|
137
|
-
]
|
|
138
|
-
`);
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
it('should skip hidden input', () => {
|
|
142
|
-
const element = htmlToElement(`<div><input hidden /><button /></div>`);
|
|
143
|
-
const focusable = getFocusableElements(element);
|
|
144
|
-
expect(focusable).toMatchInlineSnapshot(`
|
|
145
|
-
[
|
|
146
|
-
<button />,
|
|
147
|
-
]
|
|
148
|
-
`);
|
|
149
|
-
});
|
|
150
|
-
});
|
|
151
|
-
});
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { DISABLED_SELECTOR, TABBABLE_ELEMENTS_SELECTOR } from './constants';
|
|
2
|
-
|
|
3
|
-
const isNotDisabled = (element: HTMLElement) => !element.matches(DISABLED_SELECTOR);
|
|
4
|
-
|
|
5
|
-
export function getFocusableElements(element: HTMLElement): HTMLElement[] {
|
|
6
|
-
return Array.from(element.querySelectorAll<HTMLElement>(TABBABLE_ELEMENTS_SELECTOR)).filter(isNotDisabled);
|
|
7
|
-
}
|
package/dist/src/utils/index.ts
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { WINDOW } from '@lumx/react/constants';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Check if browser is IE
|
|
5
|
-
* @return Browser is IE or not
|
|
6
|
-
*/
|
|
7
|
-
export const isInternetExplorer = () => {
|
|
8
|
-
const userAgent = WINDOW?.navigator?.userAgent;
|
|
9
|
-
if (!userAgent) {
|
|
10
|
-
return false;
|
|
11
|
-
}
|
|
12
|
-
const msie = userAgent.indexOf('MSIE ');
|
|
13
|
-
const isIEVersion = !!userAgent.match(/Trident.*rv:11\./);
|
|
14
|
-
return msie > 0 || isIEVersion;
|
|
15
|
-
};
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import last from 'lodash/last';
|
|
2
|
-
import pull from 'lodash/pull';
|
|
3
|
-
|
|
4
|
-
export type Listener = { enable(): void; disable(): void };
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Keep track of listeners, only the last registered listener gets activated at any point (previously registered
|
|
8
|
-
* listener are disabled).
|
|
9
|
-
* When a listener gets unregistered, the previously registered listener gets enabled again.
|
|
10
|
-
*/
|
|
11
|
-
export function makeListenerTowerContext() {
|
|
12
|
-
const LISTENERS: Listener[] = [];
|
|
13
|
-
|
|
14
|
-
return {
|
|
15
|
-
register(listener: Listener) {
|
|
16
|
-
// Disable previous listener.
|
|
17
|
-
last(LISTENERS)?.disable();
|
|
18
|
-
// Keep track of current listener.
|
|
19
|
-
LISTENERS.push(listener);
|
|
20
|
-
// Enable current listener.
|
|
21
|
-
listener.enable();
|
|
22
|
-
},
|
|
23
|
-
unregister(listener: Listener) {
|
|
24
|
-
// Disable current listener.
|
|
25
|
-
listener.disable();
|
|
26
|
-
// Remove current listener.
|
|
27
|
-
pull(LISTENERS, listener);
|
|
28
|
-
// Enable previous listener.
|
|
29
|
-
last(LISTENERS)?.enable();
|
|
30
|
-
},
|
|
31
|
-
};
|
|
32
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { Falsy } from '@lumx/react/utils/type';
|
|
2
|
-
import { MutableRefObject } from 'react';
|
|
3
|
-
|
|
4
|
-
type FnRef<T> = (value: T) => void;
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Merge refs into a single function ref.
|
|
8
|
-
*
|
|
9
|
-
* @param refs React references to merge.
|
|
10
|
-
* @return the merged ref.
|
|
11
|
-
*/
|
|
12
|
-
export function mergeRefs<T>(...refs: Array<MutableRefObject<T | null> | FnRef<T> | Falsy>): FnRef<T> {
|
|
13
|
-
return (value) =>
|
|
14
|
-
refs.forEach((ref) => {
|
|
15
|
-
if (typeof ref === 'function') {
|
|
16
|
-
ref(value);
|
|
17
|
-
} else if (ref) {
|
|
18
|
-
// eslint-disable-next-line no-param-reassign
|
|
19
|
-
(ref as MutableRefObject<T>).current = value;
|
|
20
|
-
}
|
|
21
|
-
});
|
|
22
|
-
}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import concat from 'lodash/concat';
|
|
2
|
-
import dropRight from 'lodash/dropRight';
|
|
3
|
-
import last from 'lodash/last';
|
|
4
|
-
import partition from 'lodash/partition';
|
|
5
|
-
import reduce from 'lodash/reduce';
|
|
6
|
-
import { Predicate } from './type';
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* Similar to lodash `partition` function but working with multiple predicates.
|
|
10
|
-
*
|
|
11
|
-
* @example
|
|
12
|
-
* const isString = (s) => typeof s === 'string'
|
|
13
|
-
* const isNumber = (s) => typeof s === 'number'
|
|
14
|
-
* const [strings, numbers, others] = partitionMulti(['a', 1, 'b', false], [isString, isNumber])
|
|
15
|
-
* //=> [['a', 'b'], [1], [false]]
|
|
16
|
-
*
|
|
17
|
-
* @param elements array of elements
|
|
18
|
-
* @param predicates array of predicates to apply on elements
|
|
19
|
-
* @return partitioned elements by the given predicates
|
|
20
|
-
*/
|
|
21
|
-
export function partitionMulti<T>(elements: T[], predicates: Array<Predicate<T>>): T[][] {
|
|
22
|
-
return reduce(
|
|
23
|
-
predicates,
|
|
24
|
-
(partitioned: T[][], predicate: Predicate<T>) =>
|
|
25
|
-
concat(dropRight(partitioned), partition(last(partitioned), predicate)),
|
|
26
|
-
[elements],
|
|
27
|
-
);
|
|
28
|
-
}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import React, { ReactElement, ReactNode } from 'react';
|
|
2
|
-
|
|
3
|
-
interface Props {
|
|
4
|
-
linkAs: any;
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Render link with default <a> HTML component or a custom one provided by `linkAs`.
|
|
9
|
-
*
|
|
10
|
-
* Can be used to inject the `Link` component from `react-router` and provide better a11y on LumX components.
|
|
11
|
-
*
|
|
12
|
-
* @param linkAs Custom link component.
|
|
13
|
-
* @param children Link children.
|
|
14
|
-
* @return A link.
|
|
15
|
-
*/
|
|
16
|
-
export const renderLink = <P extends Props>({ linkAs, ...forwardedProps }: P, ...children: ReactNode[]): ReactElement =>
|
|
17
|
-
React.createElement(linkAs || 'a', forwardedProps, ...children);
|
package/dist/src/utils/type.ts
DELETED
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
import get from 'lodash/get';
|
|
2
|
-
import React, { ReactElement, ReactNode, Ref } from 'react';
|
|
3
|
-
import { Theme } from '@lumx/react';
|
|
4
|
-
|
|
5
|
-
/** Get types of the values of a record. */
|
|
6
|
-
export type ValueOf<T extends Record<any, any>> = T[keyof T];
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* Properties of a component to use to determine it's name.
|
|
10
|
-
* In the order of preference.
|
|
11
|
-
*/
|
|
12
|
-
const NAME_PROPERTIES: string[] = [
|
|
13
|
-
'type',
|
|
14
|
-
'type.displayName',
|
|
15
|
-
'displayName',
|
|
16
|
-
'name',
|
|
17
|
-
'type.name',
|
|
18
|
-
'props.mdxType',
|
|
19
|
-
'_reactInternalFiber.elementType.name',
|
|
20
|
-
];
|
|
21
|
-
|
|
22
|
-
/** LumX Component Type. */
|
|
23
|
-
export type Comp<P, T = HTMLElement> = {
|
|
24
|
-
(props: P & { ref?: Ref<T> }): ReactElement | null;
|
|
25
|
-
/** React component type. */
|
|
26
|
-
readonly $$typeof: symbol;
|
|
27
|
-
/** Component default props. */
|
|
28
|
-
defaultProps?: Partial<P>;
|
|
29
|
-
/** Component name. */
|
|
30
|
-
displayName?: string;
|
|
31
|
-
/** Component base class name. */
|
|
32
|
-
className?: string;
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
/** Union type of all heading elements */
|
|
36
|
-
export type HeadingElement = 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';
|
|
37
|
-
|
|
38
|
-
/** Union type of all text elements */
|
|
39
|
-
export type TextElement = 'span' | 'p' | HeadingElement;
|
|
40
|
-
|
|
41
|
-
export interface HasTheme {
|
|
42
|
-
/**
|
|
43
|
-
* Theme adapting the component to light or dark background.
|
|
44
|
-
*/
|
|
45
|
-
theme?: Theme;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
/**
|
|
49
|
-
* Define a generic props types.
|
|
50
|
-
*/
|
|
51
|
-
export interface GenericProps {
|
|
52
|
-
/**
|
|
53
|
-
* Class name forwarded to the root element of the component.
|
|
54
|
-
*/
|
|
55
|
-
className?: string;
|
|
56
|
-
/**
|
|
57
|
-
* Any prop (particularly any supported prop for a HTML element).
|
|
58
|
-
*/
|
|
59
|
-
[propName: string]: any;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
/**
|
|
63
|
-
* Callback function type alias (use for readability)
|
|
64
|
-
*/
|
|
65
|
-
export type Callback = () => void;
|
|
66
|
-
export type Predicate<T> = (t: T) => boolean;
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* Create a predicate function that checks if a ReactNode is a react element from the given component.
|
|
70
|
-
*
|
|
71
|
-
* @param component React function component or the component name
|
|
72
|
-
* @return predicate returning true if value is instance of the component
|
|
73
|
-
*/
|
|
74
|
-
export const isComponent = <C>(component: Comp<C, any> | string) => (instance: ReactNode): instance is ReactElement => {
|
|
75
|
-
const componentName = typeof component === 'string' ? component : component.displayName;
|
|
76
|
-
|
|
77
|
-
return (
|
|
78
|
-
!!get(instance, '$$typeof') &&
|
|
79
|
-
NAME_PROPERTIES.some((nameProperty: string): boolean => get(instance, nameProperty) === componentName)
|
|
80
|
-
);
|
|
81
|
-
};
|
|
82
|
-
|
|
83
|
-
/**
|
|
84
|
-
* Similar to `isComponent` but more precise as it's not based on the component `displayName` but on the component function reference.
|
|
85
|
-
*/
|
|
86
|
-
export const isComponentType = (type: ReactElement['type']) => (node: ReactNode): node is ReactElement =>
|
|
87
|
-
React.isValidElement(node) && node.type === type;
|
|
88
|
-
|
|
89
|
-
/**
|
|
90
|
-
* JS falsy values.
|
|
91
|
-
* (excluding `NaN` as it can't be distinguished from `number`)
|
|
92
|
-
*/
|
|
93
|
-
export type Falsy = false | undefined | null | 0 | '';
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* Require either `aria-label` or `arial-labelledby` prop.
|
|
97
|
-
* If none are set, the order will prioritize `aria-labelledby` over `aria-label` as it
|
|
98
|
-
* needs a visible element.
|
|
99
|
-
*/
|
|
100
|
-
export type HasAriaLabelOrLabelledBy<T = string | undefined> = T extends string
|
|
101
|
-
? {
|
|
102
|
-
/**
|
|
103
|
-
* The id of the element to use as title of the dialog. Can be within or out of the dialog.
|
|
104
|
-
* Although it is not recommended, aria-label can be used instead if no visible element is available.
|
|
105
|
-
*/
|
|
106
|
-
'aria-labelledby': T;
|
|
107
|
-
/** The label of the dialog. */
|
|
108
|
-
'aria-label'?: undefined;
|
|
109
|
-
}
|
|
110
|
-
: {
|
|
111
|
-
'aria-label': string;
|
|
112
|
-
'aria-labelledby'?: undefined;
|
|
113
|
-
};
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
import partition from 'lodash/partition';
|
|
2
|
-
import { partitionMulti } from './partitionMulti';
|
|
3
|
-
import { isInternetExplorer } from './isInternetExplorer';
|
|
4
|
-
|
|
5
|
-
describe(`partitionMulti`, () => {
|
|
6
|
-
it('should act like partition for single predicate', () => {
|
|
7
|
-
const data = [0, 1, 2, 3, 4, 5];
|
|
8
|
-
const isEven = (n: number): boolean => n % 2 === 0;
|
|
9
|
-
|
|
10
|
-
const expected = partition(data, isEven);
|
|
11
|
-
const actual = partitionMulti(data, [isEven]);
|
|
12
|
-
|
|
13
|
-
expect(actual).toEqual(expected);
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
it('should partition on multiple predicates', () => {
|
|
17
|
-
type T = string | number | boolean;
|
|
18
|
-
const data: T[] = ['a', 1, 'b', false, true];
|
|
19
|
-
const isString = (s: T): boolean => typeof s === 'string';
|
|
20
|
-
const isNumber = (s: T): boolean => typeof s === 'number';
|
|
21
|
-
|
|
22
|
-
const [strings, numbers, others] = partitionMulti(data, [isString, isNumber]);
|
|
23
|
-
|
|
24
|
-
expect(strings).toEqual(['a', 'b']);
|
|
25
|
-
expect(numbers).toEqual([1]);
|
|
26
|
-
expect(others).toEqual([false, true]);
|
|
27
|
-
});
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
describe(`isInternetExplorer`, () => {
|
|
31
|
-
it('should detect IE 10', () => {
|
|
32
|
-
const userAgentIE10 = `Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)`;
|
|
33
|
-
Object.defineProperty(window.navigator, 'userAgent', { value: userAgentIE10, configurable: true });
|
|
34
|
-
expect(isInternetExplorer()).toEqual(true);
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
it('should detect IE 11', () => {
|
|
38
|
-
const userAgentIE11 = `Mozilla/5.0 (Windows NT 10.0; Trident/7.0; rv:11.0) like Gecko`;
|
|
39
|
-
Object.defineProperty(window.navigator, 'userAgent', { value: userAgentIE11, configurable: true });
|
|
40
|
-
expect(isInternetExplorer()).toEqual(true);
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
it('should not detect IE', () => {
|
|
44
|
-
const userAgentFirefox = `Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:74.0) Gecko/20100101 Firefox/74.0`;
|
|
45
|
-
Object.defineProperty(window.navigator, 'userAgent', { value: userAgentFirefox, configurable: true });
|
|
46
|
-
expect(isInternetExplorer()).toEqual(false);
|
|
47
|
-
});
|
|
48
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
module.exports = {};
|
package/jest/configure.js
DELETED
package/jest/index.js
DELETED
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
/* eslint-disable */
|
|
2
|
-
const tsconfig = require('../../../tsconfig');
|
|
3
|
-
const CONFIGS = require('../../../configs');
|
|
4
|
-
|
|
5
|
-
const fromPairs = (pairs) => pairs.reduce((res, [key, value]) => ({ ...res, [key]: value }), {});
|
|
6
|
-
|
|
7
|
-
const moduleNameMapper = fromPairs(
|
|
8
|
-
Object.entries(tsconfig.compilerOptions.paths).map(([k, [v]]) => [
|
|
9
|
-
`^${k.replace(/\/\*/, '(.*)')}$`,
|
|
10
|
-
`${CONFIGS.path.ROOT_PATH}/packages/${v.replace(/\/\*/, '$1')}`,
|
|
11
|
-
]),
|
|
12
|
-
);
|
|
13
|
-
|
|
14
|
-
module.exports = {
|
|
15
|
-
collectCoverageFrom: ['src/**/*.{ts,tsx}', '!src/**/*.stories.tsx'],
|
|
16
|
-
coverageDirectory: '<rootDir>jest/reports/coverage',
|
|
17
|
-
coverageReporters: ['json', 'lcov', 'html', 'text'],
|
|
18
|
-
moduleFileExtensions: ['js', 'jsx', 'ts', 'tsx'],
|
|
19
|
-
moduleNameMapper: {
|
|
20
|
-
'\\.scss$': '<rootDir>jest/__mocks__/emptyModuleMock.js',
|
|
21
|
-
...moduleNameMapper,
|
|
22
|
-
},
|
|
23
|
-
reporters: ['default'],
|
|
24
|
-
rootDir: '../',
|
|
25
|
-
setupFilesAfterEnv: [
|
|
26
|
-
'<rootDir>jest/configure.js',
|
|
27
|
-
],
|
|
28
|
-
snapshotSerializers: ['enzyme-to-json/serializer'],
|
|
29
|
-
testEnvironment: 'jsdom',
|
|
30
|
-
testMatch: ['<rootDir>src/**/?(*.)+(spec|test).[jt]s?(x)'],
|
|
31
|
-
transform: {
|
|
32
|
-
'^.+\\.(t|j)sx?$': '<rootDir>jest/transform.js',
|
|
33
|
-
// Mock file import returning their file path.
|
|
34
|
-
'\\.(jpg|jpeg|png|gif)$': '<rootDir>jest/__mocks__/emptyFileMockTransformer.js',
|
|
35
|
-
},
|
|
36
|
-
};
|
package/jest/transform.js
DELETED
package/rollup.config.js
DELETED
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
import path from 'path';
|
|
2
|
-
import commonjs from '@rollup/plugin-commonjs';
|
|
3
|
-
import resolve from '@rollup/plugin-node-resolve';
|
|
4
|
-
import analyze from 'rollup-plugin-analyzer';
|
|
5
|
-
import babel from 'rollup-plugin-babel';
|
|
6
|
-
import cleaner from 'rollup-plugin-cleaner';
|
|
7
|
-
import copy from 'rollup-plugin-copy';
|
|
8
|
-
import dts from 'rollup-plugin-dts';
|
|
9
|
-
import peerDepsExternal from 'rollup-plugin-peer-deps-external';
|
|
10
|
-
import tsPathsResolve from 'rollup-plugin-ts-paths-resolve';
|
|
11
|
-
|
|
12
|
-
import pkg from './package.json';
|
|
13
|
-
const CONFIGS = require('../../configs');
|
|
14
|
-
|
|
15
|
-
const ROOT_PATH = path.resolve(__dirname, '..', '..');
|
|
16
|
-
const DIST_PATH = path.resolve(__dirname, pkg.publishConfig.directory);
|
|
17
|
-
export const extensions = ['.js', '.jsx', '.ts', '.tsx'];
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* List of entry modules that will get compiled and exported to NPM.
|
|
21
|
-
* All other modules are considered as internal and won't be exposed.
|
|
22
|
-
*/
|
|
23
|
-
const input = Object.fromEntries([
|
|
24
|
-
['index', 'src/index.ts'], // => @lumx/react
|
|
25
|
-
['utils/index', 'src/utils/index.ts'], // => @lumx/react/utils
|
|
26
|
-
]);
|
|
27
|
-
|
|
28
|
-
// Bundle JS code
|
|
29
|
-
const bundleJS = {
|
|
30
|
-
input,
|
|
31
|
-
output: {
|
|
32
|
-
format: 'esm',
|
|
33
|
-
sourcemap: true,
|
|
34
|
-
hoistTransitiveImports: false,
|
|
35
|
-
dir: DIST_PATH,
|
|
36
|
-
// Unnamed chunk moved to `_internal` folder
|
|
37
|
-
chunkFileNames: '_internal/[name].js',
|
|
38
|
-
},
|
|
39
|
-
plugins: [
|
|
40
|
-
/** Clean dist dir */
|
|
41
|
-
cleaner({ targets: [DIST_PATH] }),
|
|
42
|
-
/** Externalize peer dependencies. */
|
|
43
|
-
peerDepsExternal(),
|
|
44
|
-
/** Analyze created bundle. */
|
|
45
|
-
analyze(),
|
|
46
|
-
/** Resolve tsconfig paths. */
|
|
47
|
-
tsPathsResolve(),
|
|
48
|
-
/** Resolve source files. */
|
|
49
|
-
resolve({ browser: true, extensions }),
|
|
50
|
-
/** Resolve commonjs dependencies. */
|
|
51
|
-
commonjs({ include: /node_modules/ }),
|
|
52
|
-
/** Transpile JS/TS. */
|
|
53
|
-
babel({
|
|
54
|
-
extensions,
|
|
55
|
-
exclude: /node_modules/,
|
|
56
|
-
plugins: CONFIGS.babel.plugins,
|
|
57
|
-
presets: [
|
|
58
|
-
['@babel/preset-env', { targets: 'defaults' }],
|
|
59
|
-
'@babel/preset-react',
|
|
60
|
-
'@babel/preset-typescript',
|
|
61
|
-
],
|
|
62
|
-
}),
|
|
63
|
-
/** Copy additional files to dist. */
|
|
64
|
-
copy({
|
|
65
|
-
targets: [
|
|
66
|
-
{ src: path.join(ROOT_PATH, 'CONTRIBUTING.md'), dest: DIST_PATH },
|
|
67
|
-
{ src: path.join(ROOT_PATH, 'LICENSE.md'), dest: DIST_PATH },
|
|
68
|
-
{ src: path.join(__dirname, 'README.md'), dest: DIST_PATH },
|
|
69
|
-
{ src: path.join(__dirname, 'package.json'), dest: DIST_PATH },
|
|
70
|
-
{
|
|
71
|
-
src: [path.join(__dirname, 'src'), '!**/*.snap', '!**/*.test.tsx', '!**/*.test.ts'],
|
|
72
|
-
dest: DIST_PATH,
|
|
73
|
-
},
|
|
74
|
-
],
|
|
75
|
-
}),
|
|
76
|
-
],
|
|
77
|
-
};
|
|
78
|
-
|
|
79
|
-
// Bundle TS types in D.TS files
|
|
80
|
-
const bundleType = {
|
|
81
|
-
input,
|
|
82
|
-
output: {
|
|
83
|
-
format: 'esm',
|
|
84
|
-
dir: DIST_PATH,
|
|
85
|
-
// Unnamed chunk moved to `_internal` folder
|
|
86
|
-
chunkFileNames: '_internal/[name].d.ts',
|
|
87
|
-
},
|
|
88
|
-
plugins: [
|
|
89
|
-
/** Externalize peer dependencies. */
|
|
90
|
-
peerDepsExternal(),
|
|
91
|
-
/** Resolve tsconfig paths. */
|
|
92
|
-
tsPathsResolve(),
|
|
93
|
-
/** Transform TS to D.TS file. */
|
|
94
|
-
dts({ respectExternal: true }),
|
|
95
|
-
],
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
export default [bundleJS, bundleType];
|
package/storybook/build
DELETED