@lumx/react 3.1.1 → 3.1.3-alpha.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/{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 +1 -1
- package/{dist/index.d.ts → index.d.ts} +5 -5
- package/{dist/index.js → index.js} +4 -4
- package/{dist/index.js.map → index.js.map} +1 -1
- package/package.json +3 -3
- package/src/components/expansion-panel/ExpansionPanel.stories.tsx +65 -0
- package/src/components/expansion-panel/ExpansionPanel.test.tsx +2 -2
- package/src/components/expansion-panel/ExpansionPanel.tsx +8 -8
- 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,156 +0,0 @@
|
|
|
1
|
-
import React, { forwardRef, RefObject, useMemo } from 'react';
|
|
2
|
-
|
|
3
|
-
import isEmpty from 'lodash/isEmpty';
|
|
4
|
-
|
|
5
|
-
import classNames from 'classnames';
|
|
6
|
-
|
|
7
|
-
import { ColorPalette, ColorVariant, Icon, Size, Typography } from '@lumx/react';
|
|
8
|
-
import { Comp, GenericProps } from '@lumx/react/utils/type';
|
|
9
|
-
import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
|
|
10
|
-
import { renderLink } from '@lumx/react/utils/renderLink';
|
|
11
|
-
|
|
12
|
-
type HTMLAnchorProps = React.DetailedHTMLProps<React.AnchorHTMLAttributes<HTMLAnchorElement>, HTMLAnchorElement>;
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Defines the props of the component.
|
|
16
|
-
*/
|
|
17
|
-
export interface LinkProps extends GenericProps {
|
|
18
|
-
/** Color variant. */
|
|
19
|
-
color?: ColorPalette;
|
|
20
|
-
/** Lightened or darkened variant of the selected icon color. */
|
|
21
|
-
colorVariant?: ColorVariant;
|
|
22
|
-
/** Link href. */
|
|
23
|
-
href?: HTMLAnchorProps['href'];
|
|
24
|
-
/** Whether the component is disabled or not. */
|
|
25
|
-
isDisabled?: boolean;
|
|
26
|
-
/** Left icon (SVG path). */
|
|
27
|
-
leftIcon?: string;
|
|
28
|
-
/** Custom react component for the link (can be used to inject react router Link). */
|
|
29
|
-
linkAs?: 'a' | any;
|
|
30
|
-
/** Right icon (SVG path). */
|
|
31
|
-
rightIcon?: string;
|
|
32
|
-
/** Link target. */
|
|
33
|
-
target?: HTMLAnchorProps['target'];
|
|
34
|
-
/** Typography variant. */
|
|
35
|
-
typography?: Typography;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
/**
|
|
39
|
-
* Component display name.
|
|
40
|
-
*/
|
|
41
|
-
const COMPONENT_NAME = 'Link';
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Component default class name and class prefix.
|
|
45
|
-
*/
|
|
46
|
-
const CLASSNAME = getRootClassName(COMPONENT_NAME);
|
|
47
|
-
|
|
48
|
-
const getIconSize = (typography?: Typography) => {
|
|
49
|
-
switch (typography) {
|
|
50
|
-
case Typography.display1:
|
|
51
|
-
return Size.m;
|
|
52
|
-
|
|
53
|
-
case Typography.headline:
|
|
54
|
-
case Typography.title:
|
|
55
|
-
case Typography.custom.title1:
|
|
56
|
-
case Typography.custom.title2:
|
|
57
|
-
case Typography.custom.title3:
|
|
58
|
-
case Typography.custom.title4:
|
|
59
|
-
case Typography.custom.title5:
|
|
60
|
-
case Typography.custom.title6:
|
|
61
|
-
case Typography.body2:
|
|
62
|
-
case Typography.subtitle2:
|
|
63
|
-
return Size.s;
|
|
64
|
-
|
|
65
|
-
case Typography.body1:
|
|
66
|
-
case Typography.subtitle1:
|
|
67
|
-
return Size.xs;
|
|
68
|
-
|
|
69
|
-
case Typography.caption:
|
|
70
|
-
case Typography.overline:
|
|
71
|
-
return Size.xxs;
|
|
72
|
-
|
|
73
|
-
default:
|
|
74
|
-
return Size.s;
|
|
75
|
-
}
|
|
76
|
-
};
|
|
77
|
-
|
|
78
|
-
/**
|
|
79
|
-
* Link component.
|
|
80
|
-
*
|
|
81
|
-
* @param props Component props.
|
|
82
|
-
* @param ref Component ref.
|
|
83
|
-
* @return React element.
|
|
84
|
-
*/
|
|
85
|
-
export const Link: Comp<LinkProps, HTMLAnchorElement | HTMLButtonElement> = forwardRef((props, ref) => {
|
|
86
|
-
const {
|
|
87
|
-
children,
|
|
88
|
-
className,
|
|
89
|
-
color,
|
|
90
|
-
colorVariant,
|
|
91
|
-
disabled,
|
|
92
|
-
isDisabled = disabled,
|
|
93
|
-
href,
|
|
94
|
-
leftIcon,
|
|
95
|
-
linkAs,
|
|
96
|
-
rightIcon,
|
|
97
|
-
target,
|
|
98
|
-
typography,
|
|
99
|
-
...forwardedProps
|
|
100
|
-
} = props;
|
|
101
|
-
const renderedChildren = useMemo(
|
|
102
|
-
() => (
|
|
103
|
-
<>
|
|
104
|
-
{leftIcon && !isEmpty(leftIcon) && (
|
|
105
|
-
<Icon icon={leftIcon} className={`${CLASSNAME}__left-icon`} size={getIconSize(typography)} />
|
|
106
|
-
)}
|
|
107
|
-
|
|
108
|
-
{children && (
|
|
109
|
-
<span
|
|
110
|
-
className={classNames(`${CLASSNAME}__content`, {
|
|
111
|
-
[`lumx-typography-${typography}`]: typography,
|
|
112
|
-
})}
|
|
113
|
-
>
|
|
114
|
-
{children}
|
|
115
|
-
</span>
|
|
116
|
-
)}
|
|
117
|
-
|
|
118
|
-
{rightIcon && !isEmpty(rightIcon) && (
|
|
119
|
-
<Icon icon={rightIcon} className={`${CLASSNAME}__right-icon`} size={getIconSize(typography)} />
|
|
120
|
-
)}
|
|
121
|
-
</>
|
|
122
|
-
),
|
|
123
|
-
[leftIcon, typography, children, rightIcon],
|
|
124
|
-
);
|
|
125
|
-
|
|
126
|
-
/**
|
|
127
|
-
* If there is no linkAs prop and no href, we returned a <button> instead of a <a>.
|
|
128
|
-
* If the component is disabled, we also returned a <button> since disabled is not compatible with <a>.
|
|
129
|
-
*/
|
|
130
|
-
if ((!linkAs && isEmpty(href)) || isDisabled) {
|
|
131
|
-
return (
|
|
132
|
-
<button
|
|
133
|
-
type="button"
|
|
134
|
-
{...forwardedProps}
|
|
135
|
-
ref={ref as RefObject<HTMLButtonElement>}
|
|
136
|
-
disabled={isDisabled}
|
|
137
|
-
className={classNames(className, handleBasicClasses({ prefix: CLASSNAME, color, colorVariant }))}
|
|
138
|
-
>
|
|
139
|
-
{renderedChildren}
|
|
140
|
-
</button>
|
|
141
|
-
);
|
|
142
|
-
}
|
|
143
|
-
return renderLink(
|
|
144
|
-
{
|
|
145
|
-
linkAs,
|
|
146
|
-
...forwardedProps,
|
|
147
|
-
href,
|
|
148
|
-
target,
|
|
149
|
-
className: classNames(className, handleBasicClasses({ prefix: CLASSNAME, color, colorVariant })),
|
|
150
|
-
ref: ref as RefObject<HTMLAnchorElement>,
|
|
151
|
-
},
|
|
152
|
-
renderedChildren,
|
|
153
|
-
);
|
|
154
|
-
});
|
|
155
|
-
Link.displayName = COMPONENT_NAME;
|
|
156
|
-
Link.className = CLASSNAME;
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
|
2
|
-
|
|
3
|
-
exports[`<Link> Snapshots and structure should render a button if href attribute is missing 1`] = `
|
|
4
|
-
<button
|
|
5
|
-
className="lumx-link"
|
|
6
|
-
type="button"
|
|
7
|
-
/>
|
|
8
|
-
`;
|
|
9
|
-
|
|
10
|
-
exports[`<Link> Snapshots and structure should render color & color variant 1`] = `
|
|
11
|
-
<a
|
|
12
|
-
className="lumx-link lumx-link--color-primary lumx-link--color-variant-D1"
|
|
13
|
-
href="https://google.com"
|
|
14
|
-
/>
|
|
15
|
-
`;
|
|
16
|
-
|
|
17
|
-
exports[`<Link> Snapshots and structure should render correctly 1`] = `
|
|
18
|
-
<a
|
|
19
|
-
className="lumx-link"
|
|
20
|
-
href="https://google.com"
|
|
21
|
-
/>
|
|
22
|
-
`;
|
|
23
|
-
|
|
24
|
-
exports[`<Link> Snapshots and structure should render typography 1`] = `
|
|
25
|
-
<a
|
|
26
|
-
className="lumx-link"
|
|
27
|
-
href="https://google.com"
|
|
28
|
-
/>
|
|
29
|
-
`;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './Link';
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
/* istanbul ignore file */
|
|
2
|
-
import { landscapeImageKnob, portraitImageKnob } from '@lumx/react/stories/knobs/image';
|
|
3
|
-
import { text } from '@storybook/addon-knobs';
|
|
4
|
-
import React from 'react';
|
|
5
|
-
import { Size } from '..';
|
|
6
|
-
import { LinkPreview } from './LinkPreview';
|
|
7
|
-
|
|
8
|
-
export default { title: 'LumX components/link-preview/Link preview' };
|
|
9
|
-
|
|
10
|
-
const LONG_LOREM_IPSUM = `Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ut quam sollicitudin, viverra quam eget, pretium tellus. Praesent sit amet augue in odio varius accumsan vitae quis nunc. Aliquam iaculis neque at augue laoreet, eu sagittis dolor tempus. Nullam sit amet bibendum velit, in pharetra lorem. Aliquam semper accumsan placerat. Sed felis risus, efficitur non eros non, rhoncus viverra lectus. Aliquam eget interdum tellus. Praesent non ex ut urna tempus facilisis. Sed tellus tortor, pharetra vel velit sit amet, aliquet condimentum quam. Sed dictum nibh eget nibh ullamcorper dignissim. Vestibulum elementum at mauris sit amet iaculis. Maecenas pretium luctus enim vel commodo. Cras accumsan sagittis eros, vel maximus sem molestie id. Lorem ipsum dolor sit amet, consectetur adipiscing elit.
|
|
11
|
-
|
|
12
|
-
Mauris ultrices pellentesque vestibulum. Etiam vel turpis at eros condimentum feugiat nec sit amet diam. Fusce pellentesque vulputate est sed ultrices. Etiam arcu tellus, dignissim non dui mattis, suscipit pellentesque erat. Aliquam congue magna nec varius suscipit. Sed mattis fringilla viverra. Donec pulvinar ex ac augue feugiat, a vulputate mauris suscipit. Morbi eget lorem purus. In pretium ligula non ex auctor, ornare dignissim orci dictum. Nulla ornare, risus non tincidunt blandit, massa massa mollis velit, id vulputate mi ligula ut metus. Vestibulum mattis tincidunt lorem, ac commodo felis ultricies interdum. Proin fermentum eu nibh a suscipit. Morbi eu pretium sapien. Pellentesque pretium purus eros, eget feugiat nisl dapibus at.`;
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* LinkPreview story
|
|
16
|
-
* @return regular LinkPreview.
|
|
17
|
-
*/
|
|
18
|
-
export const RegularLinkPreview = ({ theme }: any) => (
|
|
19
|
-
<LinkPreview
|
|
20
|
-
title={text('Title', 'Link title')}
|
|
21
|
-
description={text('Description', LONG_LOREM_IPSUM)}
|
|
22
|
-
link={text('URL', 'https://google.com')}
|
|
23
|
-
theme={theme}
|
|
24
|
-
thumbnailProps={{ image: portraitImageKnob(), alt: 'Portrait' }}
|
|
25
|
-
/>
|
|
26
|
-
);
|
|
27
|
-
|
|
28
|
-
/**
|
|
29
|
-
* LinkPreview story
|
|
30
|
-
* @return regular LinkPreview without thumbnail.
|
|
31
|
-
*/
|
|
32
|
-
export const NoThumbnail = ({ theme }: any) => (
|
|
33
|
-
<LinkPreview
|
|
34
|
-
title={text('Title', 'Link title')}
|
|
35
|
-
description={text('Description', LONG_LOREM_IPSUM)}
|
|
36
|
-
link={text('URL', 'https://google.com')}
|
|
37
|
-
theme={theme}
|
|
38
|
-
/>
|
|
39
|
-
);
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* LinkPreview story
|
|
43
|
-
* @return regular LinkPreview without thumbnail, title and description.
|
|
44
|
-
*/
|
|
45
|
-
export const OnlyUrl = ({ theme }: any) => <LinkPreview link={text('URL', 'https://google.com')} theme={theme} />;
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* LinkPreview story
|
|
49
|
-
* @return big LinkPreview.
|
|
50
|
-
*/
|
|
51
|
-
export const BigLinkPreview = ({ theme }: any) => (
|
|
52
|
-
<div style={{ width: 400 }}>
|
|
53
|
-
<LinkPreview
|
|
54
|
-
title={text('Title', 'Link title')}
|
|
55
|
-
description={text('Description', LONG_LOREM_IPSUM)}
|
|
56
|
-
link={text('URL', 'https://google.com')}
|
|
57
|
-
theme={theme}
|
|
58
|
-
thumbnailProps={{ image: landscapeImageKnob(), alt: 'Landscape' }}
|
|
59
|
-
size={Size.big}
|
|
60
|
-
/>
|
|
61
|
-
</div>
|
|
62
|
-
);
|
|
63
|
-
|
|
64
|
-
/**
|
|
65
|
-
* LinkPreview story
|
|
66
|
-
* @return big LinkPreview without thumbnail.
|
|
67
|
-
*/
|
|
68
|
-
export const BigWithoutThumbnail = ({ theme }: any) => (
|
|
69
|
-
<div style={{ width: 400 }}>
|
|
70
|
-
<LinkPreview
|
|
71
|
-
title={text('Title', 'Link title')}
|
|
72
|
-
description={text('Description', LONG_LOREM_IPSUM)}
|
|
73
|
-
link={text('URL', 'https://google.com')}
|
|
74
|
-
theme={theme}
|
|
75
|
-
size={Size.big}
|
|
76
|
-
/>
|
|
77
|
-
</div>
|
|
78
|
-
);
|
|
79
|
-
|
|
80
|
-
/**
|
|
81
|
-
* LinkPreview story
|
|
82
|
-
* @return big LinkPreview without thumbnail, title and description.
|
|
83
|
-
*/
|
|
84
|
-
export const BigWithOnlyUrl = ({ theme }: any) => (
|
|
85
|
-
<div style={{ width: 400 }}>
|
|
86
|
-
<LinkPreview link={text('URL', 'https://google.com')} theme={theme} size={Size.big} />
|
|
87
|
-
</div>
|
|
88
|
-
);
|
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
import React, { ReactElement } from 'react';
|
|
2
|
-
|
|
3
|
-
import { mount, shallow } from 'enzyme';
|
|
4
|
-
import 'jest-enzyme';
|
|
5
|
-
|
|
6
|
-
import { commonTestsSuite, Wrapper } from '@lumx/react/testing/utils';
|
|
7
|
-
import { getBasicClass } from '@lumx/react/utils/className';
|
|
8
|
-
import { Link, Thumbnail } from '@lumx/react';
|
|
9
|
-
|
|
10
|
-
import { Size, Theme } from '..';
|
|
11
|
-
import { LinkPreview, LinkPreviewProps } from './LinkPreview';
|
|
12
|
-
|
|
13
|
-
const DEFAULT_PROPS = LinkPreview.defaultProps as any;
|
|
14
|
-
const CLASSNAME = LinkPreview.className as string;
|
|
15
|
-
|
|
16
|
-
type SetupProps = Partial<LinkPreviewProps>;
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* Mounts the component and returns common DOM elements / data needed in multiple tests further down.
|
|
20
|
-
*/
|
|
21
|
-
const setup = (propsOverride: SetupProps = {}, shallowRendering = true) => {
|
|
22
|
-
const props: any = { ...propsOverride };
|
|
23
|
-
const renderer: (el: ReactElement) => Wrapper = shallowRendering ? shallow : mount;
|
|
24
|
-
const wrapper: Wrapper = renderer(<LinkPreview {...props} />);
|
|
25
|
-
|
|
26
|
-
return {
|
|
27
|
-
thumbnail: wrapper.find(Thumbnail),
|
|
28
|
-
title: wrapper.find(`.${CLASSNAME}__title`),
|
|
29
|
-
description: wrapper.find(`.${CLASSNAME}__description`),
|
|
30
|
-
link: wrapper.find(`.${CLASSNAME}__link`).find(Link),
|
|
31
|
-
props,
|
|
32
|
-
wrapper,
|
|
33
|
-
};
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
describe(`<${LinkPreview.displayName}>`, () => {
|
|
37
|
-
it('should render with default props', () => {
|
|
38
|
-
const { wrapper, thumbnail, title, link, description } = setup();
|
|
39
|
-
expect(wrapper).toHaveClassName(CLASSNAME);
|
|
40
|
-
|
|
41
|
-
['size', 'theme'].forEach((type) => {
|
|
42
|
-
expect(wrapper).toHaveClassName(getBasicClass({ prefix: CLASSNAME, type, value: DEFAULT_PROPS[type] }));
|
|
43
|
-
});
|
|
44
|
-
expect(thumbnail).not.toExist();
|
|
45
|
-
expect(title).not.toExist();
|
|
46
|
-
expect(link).toExist();
|
|
47
|
-
expect(link).toHaveProp('tabIndex', undefined);
|
|
48
|
-
expect(description).not.toExist();
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
it('should render with only the title', () => {
|
|
52
|
-
const { title, link } = setup({ title: 'Title' });
|
|
53
|
-
|
|
54
|
-
expect(title).toExist();
|
|
55
|
-
expect(link).toExist();
|
|
56
|
-
expect(link).toHaveProp('tabIndex', '-1');
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
it('should render with complete props', () => {
|
|
60
|
-
const { wrapper, thumbnail, title, link, description, props } = setup({
|
|
61
|
-
size: Size.big,
|
|
62
|
-
theme: Theme.dark,
|
|
63
|
-
thumbnailProps: { image: 'https://example.com/thumbnail.jpg', alt: '' },
|
|
64
|
-
link: 'https://example.com',
|
|
65
|
-
linkProps: { 'data-custom-attr': 'true' },
|
|
66
|
-
title: 'Title',
|
|
67
|
-
description: 'Description',
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
const validateLink = (linkElement: any) => {
|
|
71
|
-
expect(linkElement).toHaveProp('href', props.link);
|
|
72
|
-
// Props forwarding
|
|
73
|
-
expect(linkElement).toHaveProp('data-custom-attr', 'true');
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
expect(wrapper).toExist();
|
|
77
|
-
|
|
78
|
-
// Thumbnail
|
|
79
|
-
expect(thumbnail).toExist();
|
|
80
|
-
validateLink((thumbnail as any).dive());
|
|
81
|
-
|
|
82
|
-
// Title
|
|
83
|
-
expect(title).toHaveText(props.title);
|
|
84
|
-
validateLink(title.find(Link));
|
|
85
|
-
|
|
86
|
-
// Link
|
|
87
|
-
expect(link).toHaveText(props.link);
|
|
88
|
-
validateLink(link.find(Link));
|
|
89
|
-
|
|
90
|
-
// Description
|
|
91
|
-
expect(description).toHaveText(props.description);
|
|
92
|
-
|
|
93
|
-
// Size prop applied
|
|
94
|
-
expect(wrapper).toHaveClassName(getBasicClass({ prefix: CLASSNAME, type: 'size', value: props.size }));
|
|
95
|
-
|
|
96
|
-
// Dark theme applied
|
|
97
|
-
expect(wrapper).toHaveClassName(getBasicClass({ prefix: CLASSNAME, type: 'theme', value: Theme.dark }));
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
// Common tests suite.
|
|
101
|
-
commonTestsSuite(setup, { className: 'wrapper', prop: 'wrapper' }, { className: CLASSNAME });
|
|
102
|
-
});
|
|
@@ -1,158 +0,0 @@
|
|
|
1
|
-
import React, { forwardRef } from 'react';
|
|
2
|
-
|
|
3
|
-
import classNames from 'classnames';
|
|
4
|
-
|
|
5
|
-
import {
|
|
6
|
-
AspectRatio,
|
|
7
|
-
ColorPalette,
|
|
8
|
-
ColorVariant,
|
|
9
|
-
Link,
|
|
10
|
-
LinkProps,
|
|
11
|
-
Size,
|
|
12
|
-
Theme,
|
|
13
|
-
Thumbnail,
|
|
14
|
-
ThumbnailProps,
|
|
15
|
-
} from '@lumx/react';
|
|
16
|
-
|
|
17
|
-
import { Comp, GenericProps, HeadingElement, HasTheme } from '@lumx/react/utils/type';
|
|
18
|
-
import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* Defines the props of the component.
|
|
22
|
-
*/
|
|
23
|
-
export interface LinkPreviewProps extends GenericProps, HasTheme {
|
|
24
|
-
/** Description. */
|
|
25
|
-
description?: string;
|
|
26
|
-
/** Link URL. */
|
|
27
|
-
link: string;
|
|
28
|
-
/** Custom react component for the link (can be used to inject react router Link). */
|
|
29
|
-
linkAs?: 'a' | any;
|
|
30
|
-
/** Props to pass to the link (minus those already set by the LinkPreview props). */
|
|
31
|
-
linkProps?: Omit<LinkProps, 'color' | 'colorVariant' | 'href' | 'target'>;
|
|
32
|
-
/** Size variant. */
|
|
33
|
-
size?: Extract<Size, 'regular' | 'big'>;
|
|
34
|
-
/** Thumbnail for the link preview. */
|
|
35
|
-
thumbnailProps?: ThumbnailProps;
|
|
36
|
-
/** Title. */
|
|
37
|
-
title?: string;
|
|
38
|
-
/** Customize the title heading tag. */
|
|
39
|
-
titleHeading?: HeadingElement;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
/**
|
|
43
|
-
* Component display name.
|
|
44
|
-
*/
|
|
45
|
-
const COMPONENT_NAME = 'LinkPreview';
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* Component default class name and class prefix.
|
|
49
|
-
*/
|
|
50
|
-
const CLASSNAME = getRootClassName(COMPONENT_NAME);
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* Component default props.
|
|
54
|
-
*/
|
|
55
|
-
const DEFAULT_PROPS = {
|
|
56
|
-
size: Size.regular,
|
|
57
|
-
theme: Theme.light,
|
|
58
|
-
titleHeading: 'h2',
|
|
59
|
-
} as const;
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* LinkPreview component.
|
|
63
|
-
*
|
|
64
|
-
* @param props Component props.
|
|
65
|
-
* @param ref Component ref.
|
|
66
|
-
* @return React element.
|
|
67
|
-
*/
|
|
68
|
-
export const LinkPreview: Comp<LinkPreviewProps, HTMLDivElement> = forwardRef((props, ref) => {
|
|
69
|
-
const {
|
|
70
|
-
className,
|
|
71
|
-
description,
|
|
72
|
-
link,
|
|
73
|
-
linkAs,
|
|
74
|
-
linkProps,
|
|
75
|
-
size,
|
|
76
|
-
theme,
|
|
77
|
-
thumbnailProps,
|
|
78
|
-
title,
|
|
79
|
-
titleHeading,
|
|
80
|
-
...forwardedProps
|
|
81
|
-
} = props;
|
|
82
|
-
// Use title heading as title wrapper (see DEFAULT_PROPS for the default value).
|
|
83
|
-
const TitleHeading = titleHeading as HeadingElement;
|
|
84
|
-
|
|
85
|
-
return (
|
|
86
|
-
<article
|
|
87
|
-
ref={ref}
|
|
88
|
-
{...forwardedProps}
|
|
89
|
-
className={classNames(
|
|
90
|
-
className,
|
|
91
|
-
handleBasicClasses({
|
|
92
|
-
prefix: CLASSNAME,
|
|
93
|
-
size: size === Size.big && thumbnailProps ? Size.big : Size.regular,
|
|
94
|
-
theme,
|
|
95
|
-
}),
|
|
96
|
-
)}
|
|
97
|
-
>
|
|
98
|
-
<div className={`${CLASSNAME}__wrapper`}>
|
|
99
|
-
{thumbnailProps && (
|
|
100
|
-
<div className={`${CLASSNAME}__thumbnail`}>
|
|
101
|
-
<Thumbnail
|
|
102
|
-
{...thumbnailProps}
|
|
103
|
-
linkAs={linkAs}
|
|
104
|
-
linkProps={{
|
|
105
|
-
...linkProps,
|
|
106
|
-
href: link,
|
|
107
|
-
target: '_blank',
|
|
108
|
-
// Avoid redundant links in focus order
|
|
109
|
-
tabIndex: -1,
|
|
110
|
-
}}
|
|
111
|
-
aspectRatio={AspectRatio.free}
|
|
112
|
-
fillHeight
|
|
113
|
-
/>
|
|
114
|
-
</div>
|
|
115
|
-
)}
|
|
116
|
-
|
|
117
|
-
<div className={`${CLASSNAME}__container`}>
|
|
118
|
-
{title && (
|
|
119
|
-
<TitleHeading className={`${CLASSNAME}__title`}>
|
|
120
|
-
<Link
|
|
121
|
-
{...linkProps}
|
|
122
|
-
linkAs={linkAs}
|
|
123
|
-
target="_blank"
|
|
124
|
-
href={link}
|
|
125
|
-
color={theme === Theme.light ? ColorPalette.dark : ColorPalette.light}
|
|
126
|
-
colorVariant={ColorVariant.N}
|
|
127
|
-
>
|
|
128
|
-
{title}
|
|
129
|
-
</Link>
|
|
130
|
-
</TitleHeading>
|
|
131
|
-
)}
|
|
132
|
-
|
|
133
|
-
{description && <p className={`${CLASSNAME}__description`}>{description}</p>}
|
|
134
|
-
|
|
135
|
-
<div className={`${CLASSNAME}__link`}>
|
|
136
|
-
<Link
|
|
137
|
-
{...linkProps}
|
|
138
|
-
linkAs={linkAs}
|
|
139
|
-
className={classNames(`${CLASSNAME}__link`, linkProps?.className)}
|
|
140
|
-
target="_blank"
|
|
141
|
-
href={link}
|
|
142
|
-
color={theme === Theme.light ? ColorPalette.primary : ColorPalette.light}
|
|
143
|
-
colorVariant={ColorVariant.N}
|
|
144
|
-
// Avoid redundant links in focus order
|
|
145
|
-
tabIndex={title ? '-1' : undefined}
|
|
146
|
-
>
|
|
147
|
-
{link}
|
|
148
|
-
</Link>
|
|
149
|
-
</div>
|
|
150
|
-
</div>
|
|
151
|
-
</div>
|
|
152
|
-
</article>
|
|
153
|
-
);
|
|
154
|
-
});
|
|
155
|
-
|
|
156
|
-
LinkPreview.displayName = COMPONENT_NAME;
|
|
157
|
-
LinkPreview.className = CLASSNAME;
|
|
158
|
-
LinkPreview.defaultProps = DEFAULT_PROPS;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './LinkPreview';
|
|
@@ -1,141 +0,0 @@
|
|
|
1
|
-
import React, { useRef } from 'react';
|
|
2
|
-
|
|
3
|
-
import { mdiAccount, mdiOpenInNew } from '@lumx/icons';
|
|
4
|
-
import { Icon, ListDivider, ListSubheader, Size } from '@lumx/react';
|
|
5
|
-
import { action } from '@storybook/addon-actions';
|
|
6
|
-
import { select, text } from '@storybook/addon-knobs';
|
|
7
|
-
|
|
8
|
-
import { List } from './List';
|
|
9
|
-
import { ListItem } from './ListItem';
|
|
10
|
-
|
|
11
|
-
export default { title: 'LumX components/list/List' };
|
|
12
|
-
|
|
13
|
-
export const KeyboardNavigation = () => {
|
|
14
|
-
const listRef = useRef<any>();
|
|
15
|
-
const firstItemRef = useRef<any>();
|
|
16
|
-
|
|
17
|
-
const focusList = () => {
|
|
18
|
-
return listRef.current?.focus();
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
const focusFirsItem = () => {
|
|
22
|
-
return firstItemRef.current?.focus();
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
const CustomListItem = () => {
|
|
26
|
-
return <ListItem onItemSelected={action('onItemSelected custom list item')}>Custom list item</ListItem>;
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
return (
|
|
30
|
-
<>
|
|
31
|
-
<button type="button" onClick={focusList}>
|
|
32
|
-
focus list
|
|
33
|
-
</button>
|
|
34
|
-
<button type="button" onClick={focusFirsItem}>
|
|
35
|
-
focus first item
|
|
36
|
-
</button>
|
|
37
|
-
<List onListItemSelected={action('List onListItemSelected')} ref={listRef}>
|
|
38
|
-
<ListItem linkRef={firstItemRef} onItemSelected={action('onItemSelected: Clickable item 1')}>
|
|
39
|
-
Clickable item 1
|
|
40
|
-
</ListItem>
|
|
41
|
-
<ListDivider />
|
|
42
|
-
<ListItem linkProps={{ href: '#' }}>Link item 1</ListItem>
|
|
43
|
-
<>
|
|
44
|
-
<ListItem>Non clickable (=non navigable) item</ListItem>
|
|
45
|
-
<ListSubheader>Header</ListSubheader>
|
|
46
|
-
<ListItem linkProps={{ href: '#' }}>Link item 2</ListItem>
|
|
47
|
-
<ListSubheader>Header</ListSubheader>
|
|
48
|
-
</>
|
|
49
|
-
<ListItem linkProps={{ href: '#' }} isDisabled>
|
|
50
|
-
Disabled link item
|
|
51
|
-
</ListItem>
|
|
52
|
-
<ListItem onItemSelected={action('onItemSelected')} isDisabled>
|
|
53
|
-
Disabled button item
|
|
54
|
-
</ListItem>
|
|
55
|
-
<CustomListItem />
|
|
56
|
-
{[
|
|
57
|
-
<ListItem key="1" linkProps={{ href: '#' }}>
|
|
58
|
-
Link item 4
|
|
59
|
-
</ListItem>,
|
|
60
|
-
]}
|
|
61
|
-
</List>
|
|
62
|
-
<pre>{`
|
|
63
|
-
When focused:
|
|
64
|
-
arrow up/down to move focus on list item
|
|
65
|
-
tab/shift+tab to move focus on list item AND outside the list
|
|
66
|
-
`}</pre>
|
|
67
|
-
</>
|
|
68
|
-
);
|
|
69
|
-
};
|
|
70
|
-
|
|
71
|
-
export const WithItemPadding = () => {
|
|
72
|
-
const listItemSize = select('list item size', [Size.tiny, Size.regular, Size.big, Size.huge], Size.big);
|
|
73
|
-
const listItem = (
|
|
74
|
-
<ListItem
|
|
75
|
-
className="lumx-color-background-dark-L6"
|
|
76
|
-
size={listItemSize}
|
|
77
|
-
linkProps={{ href: text('link href', '#') }}
|
|
78
|
-
>
|
|
79
|
-
<div>Two-line item</div>
|
|
80
|
-
<div className="lumx-color-font-dark-L2">Secondary text</div>
|
|
81
|
-
</ListItem>
|
|
82
|
-
);
|
|
83
|
-
return (
|
|
84
|
-
<>
|
|
85
|
-
Default item padding:
|
|
86
|
-
<List>
|
|
87
|
-
{listItem}
|
|
88
|
-
{listItem}
|
|
89
|
-
</List>
|
|
90
|
-
Big item padding:
|
|
91
|
-
<List itemPadding={Size.big}>
|
|
92
|
-
{listItem}
|
|
93
|
-
{listItem}
|
|
94
|
-
</List>
|
|
95
|
-
Huge item padding:
|
|
96
|
-
<List itemPadding={Size.huge}>
|
|
97
|
-
{listItem}
|
|
98
|
-
{listItem}
|
|
99
|
-
</List>
|
|
100
|
-
</>
|
|
101
|
-
);
|
|
102
|
-
};
|
|
103
|
-
|
|
104
|
-
export const AsLink = () => {
|
|
105
|
-
return (
|
|
106
|
-
<div className="demo-grid">
|
|
107
|
-
<List>
|
|
108
|
-
<ListItem
|
|
109
|
-
before={<Icon icon={mdiAccount} />}
|
|
110
|
-
className="lumx-color-background-dark-L6"
|
|
111
|
-
linkProps={{ href: '#' }}
|
|
112
|
-
>
|
|
113
|
-
<span>My first link</span>
|
|
114
|
-
</ListItem>
|
|
115
|
-
<ListItem
|
|
116
|
-
className="lumx-color-background-dark-L6"
|
|
117
|
-
after={<Icon icon={mdiOpenInNew} />}
|
|
118
|
-
linkProps={{ href: 'http://www.google.com', target: '_blank' }}
|
|
119
|
-
>
|
|
120
|
-
<span>Google</span>
|
|
121
|
-
</ListItem>
|
|
122
|
-
</List>
|
|
123
|
-
</div>
|
|
124
|
-
);
|
|
125
|
-
};
|
|
126
|
-
|
|
127
|
-
export const WithCustomChildren = () => {
|
|
128
|
-
const CustomListItem = () => {
|
|
129
|
-
return <ListItem onItemSelected={action('onItemSelected custom list item')}>Custom list item</ListItem>;
|
|
130
|
-
};
|
|
131
|
-
|
|
132
|
-
return (
|
|
133
|
-
<div className="demo-grid">
|
|
134
|
-
<List>
|
|
135
|
-
<CustomListItem />
|
|
136
|
-
<CustomListItem />
|
|
137
|
-
<CustomListItem />
|
|
138
|
-
</List>
|
|
139
|
-
</div>
|
|
140
|
-
);
|
|
141
|
-
};
|