@lumx/react 3.0.7-alpha.2 → 3.0.7-alpha.4

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.
Files changed (502) hide show
  1. package/{dist/CONTRIBUTING.md → CONTRIBUTING.md} +0 -0
  2. package/{dist/LICENSE.md → LICENSE.md} +0 -0
  3. package/{dist/_internal → _internal}/ClickAwayProvider.js +0 -0
  4. package/{dist/_internal → _internal}/ClickAwayProvider.js.map +0 -0
  5. package/{dist/_internal → _internal}/types.d.ts +1 -1
  6. package/{dist/index.d.ts → index.d.ts} +7 -7
  7. package/{dist/index.js → index.js} +0 -0
  8. package/{dist/index.js.map → index.js.map} +1 -1
  9. package/package.json +3 -3
  10. package/src/components/badge/Badge.tsx +2 -2
  11. package/src/components/button/ButtonRoot.tsx +2 -2
  12. package/src/components/chip/Chip.tsx +2 -2
  13. package/src/components/icon/Icon.tsx +2 -2
  14. package/src/components/link/Link.tsx +2 -2
  15. package/{dist/utils → utils}/index.d.ts +0 -0
  16. package/{dist/utils → utils}/index.js +0 -0
  17. package/{dist/utils → utils}/index.js.map +0 -0
  18. package/dist/README.md +0 -38
  19. package/dist/package.json +0 -117
  20. package/dist/src/components/alert-dialog/AlertDialog.stories.tsx +0 -196
  21. package/dist/src/components/alert-dialog/AlertDialog.test.tsx +0 -43
  22. package/dist/src/components/alert-dialog/AlertDialog.tsx +0 -185
  23. package/dist/src/components/alert-dialog/__snapshots__/AlertDialog.test.tsx.snap +0 -551
  24. package/dist/src/components/alert-dialog/index.ts +0 -1
  25. package/dist/src/components/autocomplete/Autocomplete.stories.tsx +0 -70
  26. package/dist/src/components/autocomplete/Autocomplete.test.tsx +0 -181
  27. package/dist/src/components/autocomplete/Autocomplete.tsx +0 -292
  28. package/dist/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -170
  29. package/dist/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -94
  30. package/dist/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
  31. package/dist/src/components/autocomplete/__mockData__/index.ts +0 -34
  32. package/dist/src/components/autocomplete/__snapshots__/Autocomplete.test.tsx.snap +0 -213
  33. package/dist/src/components/autocomplete/__snapshots__/AutocompleteMultiple.test.tsx.snap +0 -88
  34. package/dist/src/components/autocomplete/index.ts +0 -2
  35. package/dist/src/components/avatar/Avatar.stories.tsx +0 -92
  36. package/dist/src/components/avatar/Avatar.test.tsx +0 -39
  37. package/dist/src/components/avatar/Avatar.tsx +0 -112
  38. package/dist/src/components/avatar/__snapshots__/Avatar.test.tsx.snap +0 -681
  39. package/dist/src/components/avatar/index.ts +0 -1
  40. package/dist/src/components/badge/Badge.stories.tsx +0 -45
  41. package/dist/src/components/badge/Badge.test.tsx +0 -91
  42. package/dist/src/components/badge/Badge.tsx +0 -55
  43. package/dist/src/components/badge/__snapshots__/Badge.test.tsx.snap +0 -11
  44. package/dist/src/components/badge/index.ts +0 -1
  45. package/dist/src/components/button/Button.stories.tsx +0 -156
  46. package/dist/src/components/button/Button.test.tsx +0 -152
  47. package/dist/src/components/button/Button.tsx +0 -81
  48. package/dist/src/components/button/ButtonGroup.test.tsx +0 -66
  49. package/dist/src/components/button/ButtonGroup.tsx +0 -46
  50. package/dist/src/components/button/ButtonRoot.test.tsx +0 -203
  51. package/dist/src/components/button/ButtonRoot.tsx +0 -190
  52. package/dist/src/components/button/IconButton.test.tsx +0 -103
  53. package/dist/src/components/button/IconButton.tsx +0 -80
  54. package/dist/src/components/button/__snapshots__/Button.test.tsx.snap +0 -96
  55. package/dist/src/components/button/__snapshots__/ButtonGroup.test.tsx.snap +0 -22
  56. package/dist/src/components/button/__snapshots__/ButtonRoot.test.tsx.snap +0 -160
  57. package/dist/src/components/button/__snapshots__/IconButton.test.tsx.snap +0 -83
  58. package/dist/src/components/button/index.ts +0 -4
  59. package/dist/src/components/checkbox/Checkbox.stories.tsx +0 -37
  60. package/dist/src/components/checkbox/Checkbox.test.tsx +0 -114
  61. package/dist/src/components/checkbox/Checkbox.tsx +0 -145
  62. package/dist/src/components/checkbox/__snapshots__/Checkbox.test.tsx.snap +0 -141
  63. package/dist/src/components/checkbox/index.ts +0 -1
  64. package/dist/src/components/chip/Chip.stories.tsx +0 -21
  65. package/dist/src/components/chip/Chip.test.tsx +0 -199
  66. package/dist/src/components/chip/Chip.tsx +0 -154
  67. package/dist/src/components/chip/ChipGroup.test.tsx +0 -29
  68. package/dist/src/components/chip/ChipGroup.tsx +0 -62
  69. package/dist/src/components/chip/__snapshots__/Chip.test.tsx.snap +0 -12
  70. package/dist/src/components/chip/__snapshots__/ChipGroup.test.tsx.snap +0 -29
  71. package/dist/src/components/chip/index.ts +0 -2
  72. package/dist/src/components/comment-block/CommentBlock.stories.tsx +0 -30
  73. package/dist/src/components/comment-block/CommentBlock.test.tsx +0 -28
  74. package/dist/src/components/comment-block/CommentBlock.tsx +0 -174
  75. package/dist/src/components/comment-block/__snapshots__/CommentBlock.test.tsx.snap +0 -92
  76. package/dist/src/components/comment-block/index.ts +0 -1
  77. package/dist/src/components/date-picker/DatePicker.test.tsx +0 -41
  78. package/dist/src/components/date-picker/DatePicker.tsx +0 -56
  79. package/dist/src/components/date-picker/DatePickerControlled.test.tsx +0 -44
  80. package/dist/src/components/date-picker/DatePickerControlled.tsx +0 -128
  81. package/dist/src/components/date-picker/DatePickerField.stories.tsx +0 -93
  82. package/dist/src/components/date-picker/DatePickerField.test.tsx +0 -47
  83. package/dist/src/components/date-picker/DatePickerField.tsx +0 -141
  84. package/dist/src/components/date-picker/__snapshots__/DatePicker.test.tsx.snap +0 -22
  85. package/dist/src/components/date-picker/__snapshots__/DatePickerControlled.test.tsx.snap +0 -597
  86. package/dist/src/components/date-picker/__snapshots__/DatePickerField.test.tsx.snap +0 -43
  87. package/dist/src/components/date-picker/constants.ts +0 -11
  88. package/dist/src/components/date-picker/index.ts +0 -4
  89. package/dist/src/components/date-picker/types.ts +0 -28
  90. package/dist/src/components/dialog/Dialog.stories.tsx +0 -426
  91. package/dist/src/components/dialog/Dialog.test.tsx +0 -93
  92. package/dist/src/components/dialog/Dialog.tsx +0 -263
  93. package/dist/src/components/dialog/__snapshots__/Dialog.test.tsx.snap +0 -960
  94. package/dist/src/components/dialog/index.ts +0 -1
  95. package/dist/src/components/divider/Divider.test.tsx +0 -93
  96. package/dist/src/components/divider/Divider.tsx +0 -51
  97. package/dist/src/components/divider/__snapshots__/Divider.test.tsx.snap +0 -9
  98. package/dist/src/components/divider/index.ts +0 -1
  99. package/dist/src/components/drag-handle/DragHandle.tsx +0 -50
  100. package/dist/src/components/drag-handle/index.ts +0 -1
  101. package/dist/src/components/dropdown/Dropdown.stories.tsx +0 -216
  102. package/dist/src/components/dropdown/Dropdown.test.tsx +0 -97
  103. package/dist/src/components/dropdown/Dropdown.tsx +0 -184
  104. package/dist/src/components/dropdown/__snapshots__/Dropdown.test.tsx.snap +0 -35
  105. package/dist/src/components/dropdown/index.ts +0 -1
  106. package/dist/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -116
  107. package/dist/src/components/expansion-panel/ExpansionPanel.tsx +0 -170
  108. package/dist/src/components/expansion-panel/index.ts +0 -1
  109. package/dist/src/components/flag/Flag.stories.tsx +0 -23
  110. package/dist/src/components/flag/Flag.test.tsx +0 -86
  111. package/dist/src/components/flag/Flag.tsx +0 -47
  112. package/dist/src/components/flag/__snapshots__/Flag.test.tsx.snap +0 -133
  113. package/dist/src/components/flag/index.ts +0 -1
  114. package/dist/src/components/flex-box/FlexBox.stories.tsx +0 -245
  115. package/dist/src/components/flex-box/FlexBox.test.tsx +0 -65
  116. package/dist/src/components/flex-box/FlexBox.tsx +0 -98
  117. package/dist/src/components/flex-box/__snapshots__/FlexBox.test.tsx.snap +0 -492
  118. package/dist/src/components/flex-box/index.ts +0 -1
  119. package/dist/src/components/generic-block/GenericBlock.stories.jsx +0 -128
  120. package/dist/src/components/generic-block/GenericBlock.test.tsx +0 -152
  121. package/dist/src/components/generic-block/GenericBlock.tsx +0 -222
  122. package/dist/src/components/generic-block/constants.ts +0 -9
  123. package/dist/src/components/generic-block/index.ts +0 -2
  124. package/dist/src/components/grid/Grid.tsx +0 -73
  125. package/dist/src/components/grid/GridItem.tsx +0 -54
  126. package/dist/src/components/grid/index.ts +0 -2
  127. package/dist/src/components/grid-column/GridColumn.stories.jsx +0 -56
  128. package/dist/src/components/grid-column/GridColumn.test.jsx +0 -58
  129. package/dist/src/components/grid-column/GridColumn.tsx +0 -90
  130. package/dist/src/components/grid-column/index.ts +0 -1
  131. package/dist/src/components/heading/Heading.stories.tsx +0 -108
  132. package/dist/src/components/heading/Heading.test.tsx +0 -82
  133. package/dist/src/components/heading/Heading.tsx +0 -63
  134. package/dist/src/components/heading/HeadingLevelProvider.tsx +0 -30
  135. package/dist/src/components/heading/constants.ts +0 -16
  136. package/dist/src/components/heading/context.tsx +0 -13
  137. package/dist/src/components/heading/index.ts +0 -3
  138. package/dist/src/components/heading/useHeadingLevel.tsx +0 -8
  139. package/dist/src/components/icon/Icon.stories.tsx +0 -76
  140. package/dist/src/components/icon/Icon.test.tsx +0 -102
  141. package/dist/src/components/icon/Icon.tsx +0 -121
  142. package/dist/src/components/icon/__snapshots__/Icon.test.tsx.snap +0 -49
  143. package/dist/src/components/icon/index.ts +0 -1
  144. package/dist/src/components/image-block/ImageBlock.stories.tsx +0 -52
  145. package/dist/src/components/image-block/ImageBlock.test.tsx +0 -28
  146. package/dist/src/components/image-block/ImageBlock.tsx +0 -151
  147. package/dist/src/components/image-block/__snapshots__/ImageBlock.test.tsx.snap +0 -64
  148. package/dist/src/components/image-block/index.ts +0 -1
  149. package/dist/src/components/index.ts +0 -176
  150. package/dist/src/components/inline-list/InlineList.stories.tsx +0 -40
  151. package/dist/src/components/inline-list/InlineList.test.tsx +0 -41
  152. package/dist/src/components/inline-list/InlineList.tsx +0 -82
  153. package/dist/src/components/inline-list/index.ts +0 -1
  154. package/dist/src/components/input-helper/InputHelper.stories.tsx +0 -29
  155. package/dist/src/components/input-helper/InputHelper.test.tsx +0 -107
  156. package/dist/src/components/input-helper/InputHelper.tsx +0 -61
  157. package/dist/src/components/input-helper/__snapshots__/InputHelper.test.tsx.snap +0 -9
  158. package/dist/src/components/input-helper/constants.ts +0 -11
  159. package/dist/src/components/input-helper/index.ts +0 -1
  160. package/dist/src/components/input-label/InputLabel.stories.tsx +0 -15
  161. package/dist/src/components/input-label/InputLabel.test.tsx +0 -86
  162. package/dist/src/components/input-label/InputLabel.tsx +0 -59
  163. package/dist/src/components/input-label/__snapshots__/InputLabel.test.tsx.snap +0 -10
  164. package/dist/src/components/input-label/index.ts +0 -1
  165. package/dist/src/components/lightbox/Lightbox.stories.tsx +0 -83
  166. package/dist/src/components/lightbox/Lightbox.test.tsx +0 -30
  167. package/dist/src/components/lightbox/Lightbox.tsx +0 -153
  168. package/dist/src/components/lightbox/__snapshots__/Lightbox.test.tsx.snap +0 -194
  169. package/dist/src/components/lightbox/index.ts +0 -1
  170. package/dist/src/components/link/Link.stories.tsx +0 -141
  171. package/dist/src/components/link/Link.test.tsx +0 -60
  172. package/dist/src/components/link/Link.tsx +0 -156
  173. package/dist/src/components/link/__snapshots__/Link.test.tsx.snap +0 -29
  174. package/dist/src/components/link/index.ts +0 -1
  175. package/dist/src/components/link-preview/LinkPreview.stories.tsx +0 -88
  176. package/dist/src/components/link-preview/LinkPreview.test.tsx +0 -102
  177. package/dist/src/components/link-preview/LinkPreview.tsx +0 -158
  178. package/dist/src/components/link-preview/index.ts +0 -1
  179. package/dist/src/components/list/List.stories.tsx +0 -141
  180. package/dist/src/components/list/List.test.tsx +0 -29
  181. package/dist/src/components/list/List.tsx +0 -94
  182. package/dist/src/components/list/ListDivider.stories.tsx +0 -7
  183. package/dist/src/components/list/ListDivider.test.tsx +0 -29
  184. package/dist/src/components/list/ListDivider.tsx +0 -42
  185. package/dist/src/components/list/ListItem.stories.tsx +0 -62
  186. package/dist/src/components/list/ListItem.test.tsx +0 -29
  187. package/dist/src/components/list/ListItem.tsx +0 -154
  188. package/dist/src/components/list/ListSubheader.stories.tsx +0 -8
  189. package/dist/src/components/list/ListSubheader.test.tsx +0 -29
  190. package/dist/src/components/list/ListSubheader.tsx +0 -43
  191. package/dist/src/components/list/__snapshots__/List.test.tsx.snap +0 -360
  192. package/dist/src/components/list/__snapshots__/ListDivider.test.tsx.snap +0 -7
  193. package/dist/src/components/list/__snapshots__/ListItem.test.tsx.snap +0 -160
  194. package/dist/src/components/list/__snapshots__/ListSubheader.test.tsx.snap +0 -9
  195. package/dist/src/components/list/index.ts +0 -4
  196. package/dist/src/components/list/useInteractiveList.tsx +0 -202
  197. package/dist/src/components/message/Message.stories.tsx +0 -27
  198. package/dist/src/components/message/Message.test.tsx +0 -76
  199. package/dist/src/components/message/Message.tsx +0 -74
  200. package/dist/src/components/message/__snapshots__/Message.test.tsx.snap +0 -15
  201. package/dist/src/components/message/index.ts +0 -1
  202. package/dist/src/components/mosaic/Mosaic.stories.tsx +0 -85
  203. package/dist/src/components/mosaic/Mosaic.test.tsx +0 -120
  204. package/dist/src/components/mosaic/Mosaic.tsx +0 -95
  205. package/dist/src/components/mosaic/__snapshots__/Mosaic.test.tsx.snap +0 -357
  206. package/dist/src/components/mosaic/index.ts +0 -1
  207. package/dist/src/components/notification/Notification.test.tsx +0 -108
  208. package/dist/src/components/notification/Notification.tsx +0 -130
  209. package/dist/src/components/notification/Notifications.stories.tsx +0 -77
  210. package/dist/src/components/notification/__snapshots__/Notification.test.tsx.snap +0 -34
  211. package/dist/src/components/notification/constants.ts +0 -28
  212. package/dist/src/components/notification/index.ts +0 -1
  213. package/dist/src/components/popover/Popover.stories.tsx +0 -386
  214. package/dist/src/components/popover/Popover.test.tsx +0 -30
  215. package/dist/src/components/popover/Popover.tsx +0 -382
  216. package/dist/src/components/popover/__snapshots__/Popover.test.tsx.snap +0 -343
  217. package/dist/src/components/popover/index.ts +0 -1
  218. package/dist/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -75
  219. package/dist/src/components/popover-dialog/PopoverDialog.test.tsx +0 -65
  220. package/dist/src/components/popover-dialog/PopoverDialog.tsx +0 -65
  221. package/dist/src/components/popover-dialog/index.tsx +0 -1
  222. package/dist/src/components/post-block/PostBlock.test.tsx +0 -28
  223. package/dist/src/components/post-block/PostBlock.tsx +0 -123
  224. package/dist/src/components/post-block/__snapshots__/PostBlock.test.tsx.snap +0 -139
  225. package/dist/src/components/post-block/index.ts +0 -1
  226. package/dist/src/components/progress/Progress.tsx +0 -68
  227. package/dist/src/components/progress/ProgressCircular.stories.tsx +0 -18
  228. package/dist/src/components/progress/ProgressCircular.test.tsx +0 -49
  229. package/dist/src/components/progress/ProgressCircular.tsx +0 -68
  230. package/dist/src/components/progress/ProgressLinear.stories.tsx +0 -8
  231. package/dist/src/components/progress/ProgressLinear.test.tsx +0 -37
  232. package/dist/src/components/progress/ProgressLinear.tsx +0 -52
  233. package/dist/src/components/progress/index.ts +0 -3
  234. package/dist/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
  235. package/dist/src/components/progress-tracker/ProgressTracker.test.tsx +0 -57
  236. package/dist/src/components/progress-tracker/ProgressTracker.tsx +0 -89
  237. package/dist/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -42
  238. package/dist/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -66
  239. package/dist/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -128
  240. package/dist/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
  241. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -73
  242. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -67
  243. package/dist/src/components/progress-tracker/__snapshots__/ProgressTracker.test.tsx.snap +0 -41
  244. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStep.test.tsx.snap +0 -141
  245. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStepPanel.test.tsx.snap +0 -25
  246. package/dist/src/components/progress-tracker/index.ts +0 -4
  247. package/dist/src/components/radio-button/RadioButton.stories.tsx +0 -28
  248. package/dist/src/components/radio-button/RadioButton.test.tsx +0 -123
  249. package/dist/src/components/radio-button/RadioButton.tsx +0 -141
  250. package/dist/src/components/radio-button/RadioGroup.stories.tsx +0 -42
  251. package/dist/src/components/radio-button/RadioGroup.test.tsx +0 -77
  252. package/dist/src/components/radio-button/RadioGroup.tsx +0 -52
  253. package/dist/src/components/radio-button/__snapshots__/RadioButton.test.tsx.snap +0 -113
  254. package/dist/src/components/radio-button/__snapshots__/RadioGroup.test.tsx.snap +0 -26
  255. package/dist/src/components/radio-button/index.ts +0 -2
  256. package/dist/src/components/select/Select.stories.tsx +0 -399
  257. package/dist/src/components/select/Select.test.tsx +0 -359
  258. package/dist/src/components/select/Select.tsx +0 -193
  259. package/dist/src/components/select/SelectMultiple.stories.tsx +0 -227
  260. package/dist/src/components/select/SelectMultiple.test.tsx +0 -405
  261. package/dist/src/components/select/SelectMultiple.tsx +0 -198
  262. package/dist/src/components/select/WithSelectContext.tsx +0 -143
  263. package/dist/src/components/select/__snapshots__/Select.test.tsx.snap +0 -43
  264. package/dist/src/components/select/__snapshots__/SelectMultiple.test.tsx.snap +0 -87
  265. package/dist/src/components/select/constants.ts +0 -53
  266. package/dist/src/components/select/index.ts +0 -2
  267. package/dist/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
  268. package/dist/src/components/side-navigation/SideNavigation.test.tsx +0 -52
  269. package/dist/src/components/side-navigation/SideNavigation.tsx +0 -54
  270. package/dist/src/components/side-navigation/SideNavigationItem.test.tsx +0 -175
  271. package/dist/src/components/side-navigation/SideNavigationItem.tsx +0 -162
  272. package/dist/src/components/side-navigation/__snapshots__/SideNavigation.test.tsx.snap +0 -7
  273. package/dist/src/components/side-navigation/__snapshots__/SideNavigationItem.test.tsx.snap +0 -30
  274. package/dist/src/components/side-navigation/index.ts +0 -2
  275. package/dist/src/components/skeleton/SkeletonCircle.stories.tsx +0 -25
  276. package/dist/src/components/skeleton/SkeletonCircle.test.tsx +0 -28
  277. package/dist/src/components/skeleton/SkeletonCircle.tsx +0 -52
  278. package/dist/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -107
  279. package/dist/src/components/skeleton/SkeletonRectangle.test.tsx +0 -28
  280. package/dist/src/components/skeleton/SkeletonRectangle.tsx +0 -78
  281. package/dist/src/components/skeleton/SkeletonTypography.stories.tsx +0 -26
  282. package/dist/src/components/skeleton/SkeletonTypography.test.tsx +0 -28
  283. package/dist/src/components/skeleton/SkeletonTypography.tsx +0 -57
  284. package/dist/src/components/skeleton/__snapshots__/SkeletonCircle.test.tsx.snap +0 -54
  285. package/dist/src/components/skeleton/__snapshots__/SkeletonRectangle.test.tsx.snap +0 -177
  286. package/dist/src/components/skeleton/__snapshots__/SkeletonTypography.test.tsx.snap +0 -174
  287. package/dist/src/components/skeleton/index.ts +0 -3
  288. package/dist/src/components/slider/Slider.stories.tsx +0 -29
  289. package/dist/src/components/slider/Slider.test.tsx +0 -31
  290. package/dist/src/components/slider/Slider.tsx +0 -299
  291. package/dist/src/components/slider/__snapshots__/Slider.test.tsx.snap +0 -122
  292. package/dist/src/components/slider/index.ts +0 -2
  293. package/dist/src/components/slideshow/Slides.tsx +0 -124
  294. package/dist/src/components/slideshow/Slideshow.stories.tsx +0 -212
  295. package/dist/src/components/slideshow/Slideshow.test.tsx +0 -39
  296. package/dist/src/components/slideshow/Slideshow.tsx +0 -170
  297. package/dist/src/components/slideshow/SlideshowControls.stories.tsx +0 -112
  298. package/dist/src/components/slideshow/SlideshowControls.tsx +0 -241
  299. package/dist/src/components/slideshow/SlideshowItem.tsx +0 -52
  300. package/dist/src/components/slideshow/SlideshowItemGroup.tsx +0 -64
  301. package/dist/src/components/slideshow/__snapshots__/Slideshow.test.tsx.snap +0 -157
  302. package/dist/src/components/slideshow/constants.ts +0 -24
  303. package/dist/src/components/slideshow/index.ts +0 -4
  304. package/dist/src/components/slideshow/useKeyNavigate.ts +0 -28
  305. package/dist/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
  306. package/dist/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
  307. package/dist/src/components/slideshow/useSwipeNavigate.ts +0 -18
  308. package/dist/src/components/switch/Switch.stories.tsx +0 -36
  309. package/dist/src/components/switch/Switch.test.tsx +0 -189
  310. package/dist/src/components/switch/Switch.tsx +0 -141
  311. package/dist/src/components/switch/__snapshots__/Switch.test.tsx.snap +0 -179
  312. package/dist/src/components/switch/index.ts +0 -1
  313. package/dist/src/components/table/Table.test.tsx +0 -28
  314. package/dist/src/components/table/Table.tsx +0 -59
  315. package/dist/src/components/table/TableBody.test.tsx +0 -22
  316. package/dist/src/components/table/TableBody.tsx +0 -44
  317. package/dist/src/components/table/TableCell.test.tsx +0 -23
  318. package/dist/src/components/table/TableCell.tsx +0 -125
  319. package/dist/src/components/table/TableHeader.test.tsx +0 -22
  320. package/dist/src/components/table/TableHeader.tsx +0 -50
  321. package/dist/src/components/table/TableRow.test.tsx +0 -22
  322. package/dist/src/components/table/TableRow.tsx +0 -68
  323. package/dist/src/components/table/__snapshots__/Table.test.tsx.snap +0 -263
  324. package/dist/src/components/table/index.ts +0 -5
  325. package/dist/src/components/tabs/Tab.test.tsx +0 -116
  326. package/dist/src/components/tabs/Tab.tsx +0 -120
  327. package/dist/src/components/tabs/TabList.test.tsx +0 -80
  328. package/dist/src/components/tabs/TabList.tsx +0 -82
  329. package/dist/src/components/tabs/TabPanel.test.tsx +0 -74
  330. package/dist/src/components/tabs/TabPanel.tsx +0 -65
  331. package/dist/src/components/tabs/TabProvider.test.tsx +0 -42
  332. package/dist/src/components/tabs/TabProvider.tsx +0 -59
  333. package/dist/src/components/tabs/Tabs.stories.tsx +0 -134
  334. package/dist/src/components/tabs/__snapshots__/Tab.test.tsx.snap +0 -62
  335. package/dist/src/components/tabs/__snapshots__/TabList.test.tsx.snap +0 -22
  336. package/dist/src/components/tabs/__snapshots__/TabPanel.test.tsx.snap +0 -25
  337. package/dist/src/components/tabs/index.ts +0 -4
  338. package/dist/src/components/tabs/state.ts +0 -116
  339. package/dist/src/components/tabs/test.mocks.ts +0 -33
  340. package/dist/src/components/text/Text.stories.jsx +0 -75
  341. package/dist/src/components/text/Text.test.tsx +0 -108
  342. package/dist/src/components/text/Text.tsx +0 -121
  343. package/dist/src/components/text/index.ts +0 -1
  344. package/dist/src/components/text-field/TextField.stories.tsx +0 -169
  345. package/dist/src/components/text-field/TextField.test.tsx +0 -171
  346. package/dist/src/components/text-field/TextField.tsx +0 -432
  347. package/dist/src/components/text-field/__snapshots__/TextField.test.tsx.snap +0 -42
  348. package/dist/src/components/text-field/index.ts +0 -1
  349. package/dist/src/components/thumbnail/Thumbnail.stories.tsx +0 -510
  350. package/dist/src/components/thumbnail/Thumbnail.test.tsx +0 -46
  351. package/dist/src/components/thumbnail/Thumbnail.tsx +0 -222
  352. package/dist/src/components/thumbnail/__snapshots__/Thumbnail.test.tsx.snap +0 -130
  353. package/dist/src/components/thumbnail/index.ts +0 -3
  354. package/dist/src/components/thumbnail/types.ts +0 -39
  355. package/dist/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
  356. package/dist/src/components/thumbnail/useFocusPointStyle.tsx +0 -111
  357. package/dist/src/components/thumbnail/useImageLoad.ts +0 -40
  358. package/dist/src/components/toolbar/Toolbar.tsx +0 -67
  359. package/dist/src/components/toolbar/index.ts +0 -1
  360. package/dist/src/components/tooltip/Tooltip.stories.tsx +0 -172
  361. package/dist/src/components/tooltip/Tooltip.test.tsx +0 -105
  362. package/dist/src/components/tooltip/Tooltip.tsx +0 -122
  363. package/dist/src/components/tooltip/__snapshots__/Tooltip.test.tsx.snap +0 -233
  364. package/dist/src/components/tooltip/index.ts +0 -1
  365. package/dist/src/components/tooltip/useInjectTooltipRef.tsx +0 -44
  366. package/dist/src/components/tooltip/useTooltipOpen.tsx +0 -113
  367. package/dist/src/components/uploader/Uploader.test.tsx +0 -87
  368. package/dist/src/components/uploader/Uploader.tsx +0 -105
  369. package/dist/src/components/uploader/__snapshots__/Uploader.test.tsx.snap +0 -14
  370. package/dist/src/components/uploader/index.ts +0 -1
  371. package/dist/src/components/user-block/UserBlock.stories.tsx +0 -76
  372. package/dist/src/components/user-block/UserBlock.test.tsx +0 -38
  373. package/dist/src/components/user-block/UserBlock.tsx +0 -179
  374. package/dist/src/components/user-block/__snapshots__/UserBlock.test.tsx.snap +0 -362
  375. package/dist/src/components/user-block/index.ts +0 -1
  376. package/dist/src/constants.ts +0 -17
  377. package/dist/src/hooks/useBooleanState.tsx +0 -13
  378. package/dist/src/hooks/useCallbackOnEscape.ts +0 -34
  379. package/dist/src/hooks/useChipGroupNavigation.tsx +0 -75
  380. package/dist/src/hooks/useClickAway.tsx +0 -47
  381. package/dist/src/hooks/useDisableBodyScroll.ts +0 -28
  382. package/dist/src/hooks/useEventCallback.tsx +0 -17
  383. package/dist/src/hooks/useFocus.tsx +0 -21
  384. package/dist/src/hooks/useFocusTrap.ts +0 -85
  385. package/dist/src/hooks/useFocusWithin.ts +0 -33
  386. package/dist/src/hooks/useInfiniteScroll.tsx +0 -60
  387. package/dist/src/hooks/useIntersectionObserver.tsx +0 -43
  388. package/dist/src/hooks/useInterval.tsx +0 -31
  389. package/dist/src/hooks/useKeyboardListNavigation.tsx +0 -204
  390. package/dist/src/hooks/useListenFocus.tsx +0 -26
  391. package/dist/src/hooks/useOnResize.ts +0 -41
  392. package/dist/src/hooks/useRovingTabIndex.tsx +0 -90
  393. package/dist/src/hooks/useSlideshowControls.ts +0 -243
  394. package/dist/src/hooks/useStopPropagation.ts +0 -21
  395. package/dist/src/hooks/useTransitionVisibility.ts +0 -54
  396. package/dist/src/index.ts +0 -58
  397. package/dist/src/stories/chromaticForceScreenSize.tsx +0 -7
  398. package/dist/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
  399. package/dist/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
  400. package/dist/src/stories/generated/Badge/Demos.stories.tsx +0 -9
  401. package/dist/src/stories/generated/Button/Demos.stories.tsx +0 -11
  402. package/dist/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
  403. package/dist/src/stories/generated/Chip/Demos.stories.tsx +0 -11
  404. package/dist/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
  405. package/dist/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
  406. package/dist/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
  407. package/dist/src/stories/generated/Divider/Demos.stories.tsx +0 -6
  408. package/dist/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
  409. package/dist/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
  410. package/dist/src/stories/generated/Flag/Demos.stories.tsx +0 -6
  411. package/dist/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
  412. package/dist/src/stories/generated/Heading/Demos.stories.tsx +0 -6
  413. package/dist/src/stories/generated/Icon/Demos.stories.tsx +0 -8
  414. package/dist/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
  415. package/dist/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
  416. package/dist/src/stories/generated/Link/Demos.stories.tsx +0 -8
  417. package/dist/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
  418. package/dist/src/stories/generated/List/Demos.stories.tsx +0 -11
  419. package/dist/src/stories/generated/Message/Demos.stories.tsx +0 -10
  420. package/dist/src/stories/generated/Mosaic/Demos.stories.tsx +0 -9
  421. package/dist/src/stories/generated/Notification/Demos.stories.tsx +0 -6
  422. package/dist/src/stories/generated/Popover/Demos.stories.tsx +0 -11
  423. package/dist/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
  424. package/dist/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
  425. package/dist/src/stories/generated/Progress/Demos.stories.tsx +0 -7
  426. package/dist/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
  427. package/dist/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
  428. package/dist/src/stories/generated/Select/Demos.stories.tsx +0 -14
  429. package/dist/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
  430. package/dist/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
  431. package/dist/src/stories/generated/Slider/Demos.stories.tsx +0 -9
  432. package/dist/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
  433. package/dist/src/stories/generated/Switch/Demos.stories.tsx +0 -6
  434. package/dist/src/stories/generated/Table/Demos.stories.tsx +0 -6
  435. package/dist/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
  436. package/dist/src/stories/generated/TextField/Demos.stories.tsx +0 -19
  437. package/dist/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
  438. package/dist/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
  439. package/dist/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
  440. package/dist/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
  441. package/dist/src/stories/generated/UserBlock/Demos.stories.tsx +0 -10
  442. package/dist/src/stories/knobs/buttonKnob.ts +0 -9
  443. package/dist/src/stories/knobs/emphasisKnob.ts +0 -8
  444. package/dist/src/stories/knobs/enumKnob.ts +0 -14
  445. package/dist/src/stories/knobs/focusKnob.ts +0 -3
  446. package/dist/src/stories/knobs/image.ts +0 -69
  447. package/dist/src/stories/knobs/lorem.ts +0 -59
  448. package/dist/src/stories/knobs/sizeKnob.ts +0 -5
  449. package/dist/src/stories/knobs/thumbnailsKnob.ts +0 -9
  450. package/dist/src/stories/utils/CustomLink.tsx +0 -7
  451. package/dist/src/stories/withResizableBox.tsx +0 -18
  452. package/dist/src/testing/utils/commonTestsSuite.ts +0 -71
  453. package/dist/src/testing/utils/commonTestsSuiteRTL.ts +0 -55
  454. package/dist/src/testing/utils/index.ts +0 -4
  455. package/dist/src/testing/utils/itShouldRenderStories.tsx +0 -103
  456. package/dist/src/testing/utils/queries.ts +0 -19
  457. package/dist/src/untypped-modules.d.ts +0 -7
  458. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -58
  459. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -65
  460. package/dist/src/utils/ClickAwayProvider/index.ts +0 -1
  461. package/dist/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
  462. package/dist/src/utils/MaterialThemeSwitcher/index.ts +0 -1
  463. package/dist/src/utils/browserDoesNotSupportHover.test.js +0 -24
  464. package/dist/src/utils/browserDoesNotSupportHover.ts +0 -2
  465. package/dist/src/utils/clamp.ts +0 -17
  466. package/dist/src/utils/className.ts +0 -44
  467. package/dist/src/utils/event.ts +0 -1
  468. package/dist/src/utils/flattenChildren.test.tsx +0 -58
  469. package/dist/src/utils/flattenChildren.ts +0 -27
  470. package/dist/src/utils/focus/constants.ts +0 -5
  471. package/dist/src/utils/focus/getFirstAndLastFocusable.test.ts +0 -134
  472. package/dist/src/utils/focus/getFirstAndLastFocusable.ts +0 -21
  473. package/dist/src/utils/focus/getFocusableElements.test.ts +0 -151
  474. package/dist/src/utils/focus/getFocusableElements.ts +0 -7
  475. package/dist/src/utils/index.ts +0 -5
  476. package/dist/src/utils/isInternetExplorer.ts +0 -15
  477. package/dist/src/utils/makeListenerTowerContext.ts +0 -32
  478. package/dist/src/utils/mergeRefs.ts +0 -22
  479. package/dist/src/utils/partitionMulti.ts +0 -28
  480. package/dist/src/utils/renderLink.tsx +0 -17
  481. package/dist/src/utils/type.ts +0 -113
  482. package/dist/src/utils/userHasReducedMotion.ts +0 -7
  483. package/dist/src/utils/utils.test.ts +0 -48
  484. package/jest/__mocks__/@storybook/addon-actions.js +0 -3
  485. package/jest/__mocks__/@storybook/addon-knobs.js +0 -6
  486. package/jest/__mocks__/emptyFileMockTransformer.js +0 -8
  487. package/jest/__mocks__/emptyModuleMock.js +0 -1
  488. package/jest/configure.js +0 -6
  489. package/jest/index.js +0 -36
  490. package/jest/transform.js +0 -6
  491. package/rollup.config.js +0 -98
  492. package/storybook/build +0 -4
  493. package/storybook/generate-demo-stories.js +0 -59
  494. package/storybook/main.js +0 -67
  495. package/storybook/package.json +0 -13
  496. package/storybook/preview.js +0 -11
  497. package/storybook/start +0 -4
  498. package/storybook/story-block/StoryBlock.tsx +0 -49
  499. package/storybook/story-block/decorator.jsx +0 -7
  500. package/storybook/story-block/index.scss +0 -27
  501. package/storybook/yarn.lock +0 -13192
  502. package/tsconfig.json +0 -3
@@ -1,67 +0,0 @@
1
- import React, { forwardRef, ReactNode } from 'react';
2
-
3
- import classNames from 'classnames';
4
-
5
- import { Comp, GenericProps } from '@lumx/react/utils/type';
6
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
7
-
8
- /**
9
- * Defines the props of the component.
10
- */
11
- export interface ToolbarProps extends GenericProps {
12
- /** After content (placed after the label). */
13
- after?: ReactNode;
14
- /** Before content (placed before the label). */
15
- before?: ReactNode;
16
- /** Label content. */
17
- label?: ReactNode;
18
- }
19
-
20
- /**
21
- * Component display name.
22
- */
23
- const COMPONENT_NAME = 'Toolbar';
24
-
25
- /**
26
- * Component default class name and class prefix.
27
- */
28
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
29
-
30
- /**
31
- * Component default props.
32
- */
33
- const DEFAULT_PROPS: Partial<ToolbarProps> = {};
34
-
35
- /**
36
- * Toolbar component.
37
- *
38
- * @param props Component props.
39
- * @param ref Component ref.
40
- * @return React element.
41
- */
42
- export const Toolbar: Comp<ToolbarProps, HTMLDivElement> = forwardRef((props, ref) => {
43
- const { after, before, className, label, ...forwardedProps } = props;
44
-
45
- return (
46
- <div
47
- ref={ref}
48
- {...forwardedProps}
49
- className={classNames(
50
- className,
51
- handleBasicClasses({
52
- hasAfter: Boolean(after),
53
- hasBefore: Boolean(before),
54
- hasLabel: Boolean(label),
55
- prefix: CLASSNAME,
56
- }),
57
- )}
58
- >
59
- {before && <div className={`${CLASSNAME}__before`}>{before}</div>}
60
- {label && <div className={`${CLASSNAME}__label`}>{label}</div>}
61
- {after && <div className={`${CLASSNAME}__after`}>{after}</div>}
62
- </div>
63
- );
64
- });
65
- Toolbar.displayName = COMPONENT_NAME;
66
- Toolbar.className = CLASSNAME;
67
- Toolbar.defaultProps = DEFAULT_PROPS;
@@ -1 +0,0 @@
1
- export * from './Toolbar';
@@ -1,172 +0,0 @@
1
- import { mdiHelp, mdiPrinter } from '@lumx/icons';
2
- import {
3
- Button,
4
- Dialog,
5
- Dropdown,
6
- FlexBox,
7
- Icon,
8
- IconButton,
9
- Orientation,
10
- Placement,
11
- Size,
12
- Switch,
13
- Tooltip,
14
- } from '@lumx/react';
15
- import { select, text } from '@storybook/addon-knobs';
16
- import noop from 'lodash/noop';
17
- import range from 'lodash/range';
18
- import React, { Fragment, useRef, useState } from 'react';
19
-
20
- export default { title: 'LumX components/tooltip/Tooltip' };
21
-
22
- export const ForceOpen = () => {
23
- return (
24
- <Tooltip
25
- forceOpen
26
- placement={select(
27
- 'placement',
28
- [Placement.TOP, Placement.BOTTOM, Placement.RIGHT, Placement.LEFT],
29
- Placement.TOP,
30
- )}
31
- label={text('label', 'Tooltip label')}
32
- >
33
- <Button>Button</Button>
34
- </Tooltip>
35
- );
36
- };
37
-
38
- export const InlineTooltip = () => (
39
- <div className="lumx-spacing-margin-huge">
40
- Some text with a
41
- <Tooltip label="extremely complex and difficult to follow" forceOpen>
42
- <abbr style={{ borderBottom: '1px dotted', margin: '0 4px' }}>convoluted</abbr>
43
- </Tooltip>
44
- word in it. And some text with a contextual help at the end
45
- <Tooltip
46
- label="A contextual help is help that is displayed in your product or web site"
47
- placement={Placement.TOP}
48
- forceOpen
49
- >
50
- <Icon icon={mdiHelp} size={Size.xxs} style={{ display: 'inline-block', verticalAlign: 'super' }} />
51
- </Tooltip>
52
- .
53
- </div>
54
- );
55
-
56
- export const MultilineTooltip = () => (
57
- <>
58
- <Tooltip label="Only one sentence.">
59
- <Button>One line</Button>
60
- </Tooltip>
61
- <Tooltip label={'First sentence.\nSecond sentence.\nThird sentence.\n'}>
62
- <Button>Multiline</Button>
63
- </Tooltip>
64
- </>
65
- );
66
-
67
- export const EmptyTooltip = () => (
68
- <>
69
- <Tooltip label="">
70
- <Button>Empty</Button>
71
- </Tooltip>
72
- <Tooltip label={false}>
73
- <Button>Conditionnaly not displayed</Button>
74
- </Tooltip>
75
- </>
76
- );
77
-
78
- export const TooltipWithDropdown = () => {
79
- const [button, setButton] = useState<HTMLElement | null>(null);
80
- const [isOpen, setOpen] = useState(false);
81
- return (
82
- <>
83
- <Tooltip label={!isOpen && 'Tooltip'} placement="top">
84
- <Button ref={setButton} onClick={() => setOpen((o) => !o)}>
85
- Anchor
86
- </Button>
87
- </Tooltip>
88
- <Dropdown anchorRef={{ current: button }} isOpen={isOpen}>
89
- Dropdown
90
- </Dropdown>
91
- </>
92
- );
93
- };
94
-
95
- export const TooltipOnDisabledButton = () => {
96
- const [disabled, setDisabled] = useState(false);
97
-
98
- return (
99
- <>
100
- <Switch isChecked={disabled} onChange={setDisabled}>
101
- Toggle button disabled
102
- </Switch>
103
- <Tooltip label="Tooltip on disabled button">
104
- <Button isDisabled={disabled} onClick={noop}>
105
- Click to disable button
106
- </Button>
107
- </Tooltip>
108
- </>
109
- );
110
- };
111
-
112
- export const TooltipOnDifferentComponents = () => {
113
- return (
114
- <FlexBox orientation={Orientation.horizontal} className="lumx-spacing-margin-top-huge">
115
- <FlexBox fillSpace />
116
- <FlexBox fillSpace>
117
- <Tooltip forceOpen label="Tooltip on Button">
118
- <Button>Button</Button>
119
- </Tooltip>
120
- </FlexBox>
121
- <FlexBox fillSpace>
122
- <IconButton icon={mdiPrinter} label="Tooltip on IconButton" tooltipProps={{ forceOpen: true }} />
123
- </FlexBox>
124
- <FlexBox fillSpace>
125
- <Tooltip forceOpen label="Tooltip on Icon">
126
- <Icon icon={mdiPrinter} style={{ display: 'inline-block' }} />
127
- </Tooltip>
128
- </FlexBox>
129
- <FlexBox fillSpace>
130
- <Tooltip forceOpen label="Tooltip on shaped Icon">
131
- <Icon icon={mdiPrinter} hasShape />
132
- </Tooltip>
133
- </FlexBox>
134
- <FlexBox fillSpace>
135
- <Tooltip forceOpen label="Tooltip on word">
136
- <span>word</span>
137
- </Tooltip>
138
- </FlexBox>
139
- </FlexBox>
140
- );
141
- };
142
-
143
- export const HideTooltipOnHiddenAnchor = () => {
144
- const anchorRef = useRef(null);
145
- const [isOpen, setOpen] = useState(false);
146
- return (
147
- <>
148
- The tooltip should show when the button is hovered but it should disappear when the popover get in-between
149
- the mouse and the button
150
- <br />
151
- <Tooltip label="Tooltip label">
152
- <Button ref={anchorRef} onClick={() => setOpen((wasOpen) => !wasOpen)}>
153
- Open popover
154
- </Button>
155
- </Tooltip>
156
- <Dialog isOpen={isOpen} onClose={() => setOpen(false)}>
157
- Dialog
158
- </Dialog>
159
- </>
160
- );
161
- };
162
-
163
- export const StressTest = () => {
164
- return range(1000).map((i) => (
165
- <Fragment key={i}>
166
- <Tooltip label={`Label ${i}`}>
167
- <Button>Button {i}</Button>
168
- </Tooltip>
169
- <br />
170
- </Fragment>
171
- ));
172
- };
@@ -1,105 +0,0 @@
1
- import React, { ReactElement } from 'react';
2
-
3
- import { mount, shallow } from 'enzyme';
4
- import 'jest-enzyme';
5
-
6
- import { Wrapper, commonTestsSuite } from '@lumx/react/testing/utils';
7
-
8
- import { Button, Icon } from '@lumx/react';
9
- import { Tooltip, TooltipProps } from './Tooltip';
10
-
11
- const CLASSNAME = Tooltip.className as string;
12
-
13
- jest.mock('uid', () => ({ uid: () => 'uid' }));
14
-
15
- type SetupProps = Partial<TooltipProps>;
16
-
17
- /**
18
- * Mounts the component and returns common DOM elements / data needed in multiple tests further down.
19
- */
20
- const setup = (propsOverride: SetupProps = {}, shallowRendering = true) => {
21
- const props: any = { ...propsOverride };
22
- const renderer: (el: ReactElement) => Wrapper = shallowRendering ? shallow : mount;
23
- const wrapper = renderer(
24
- <Tooltip label="Tooltip" {...props}>
25
- Anchor
26
- </Tooltip>,
27
- );
28
- const tooltip = wrapper.find(`.${CLASSNAME}`);
29
-
30
- return {
31
- props,
32
- tooltip,
33
- wrapper,
34
- };
35
- };
36
-
37
- jest.mock('./useTooltipOpen', () => ({ useTooltipOpen: () => true }));
38
-
39
- describe(`<${Tooltip.displayName}>`, () => {
40
- // 1. Test render via snapshot (default states of component).
41
- describe('Snapshots and structure', () => {
42
- // Here is an example of a basic rendering check, with snapshot.
43
-
44
- it('should render correctly', () => {
45
- const { tooltip, wrapper } = setup();
46
- expect(wrapper).toMatchSnapshot();
47
-
48
- expect(tooltip).toExist();
49
- expect(tooltip).toHaveClassName(CLASSNAME);
50
- });
51
-
52
- it('should return children when empty label', () => {
53
- const wrapper = shallow(
54
- <Tooltip label="">
55
- <Icon icon="icon" />
56
- </Tooltip>,
57
- );
58
- expect(wrapper).toMatchSnapshot();
59
- });
60
-
61
- it('should wrap children', () => {
62
- // Wrap string children
63
- const wrapper1 = shallow(<Tooltip label="tooltip1">children</Tooltip>);
64
- expect(wrapper1).toMatchSnapshot();
65
-
66
- // Wrap fragment children
67
- const wrapper2 = shallow(
68
- <Tooltip label="tooltip1">
69
- <>children</>
70
- </Tooltip>,
71
- );
72
- expect(wrapper2).toMatchSnapshot();
73
- });
74
-
75
- it('should not wrap Icon', () => {
76
- const wrapper = shallow(
77
- <Tooltip label="tooltip1">
78
- <Icon icon="icon" />
79
- </Tooltip>,
80
- );
81
- expect(wrapper).toMatchSnapshot();
82
- });
83
-
84
- it('should not wrap Button', () => {
85
- const wrapper = shallow(
86
- <Tooltip label="tooltip1">
87
- <Button>button</Button>
88
- </Tooltip>,
89
- );
90
- expect(wrapper).toMatchSnapshot();
91
- });
92
-
93
- it('should work on disabled elements', () => {
94
- const wrapper = shallow(
95
- <Tooltip label="Tooltip on disabled button" forceOpen>
96
- <Button isDisabled>Empty</Button>
97
- </Tooltip>,
98
- );
99
- expect(wrapper).toMatchSnapshot();
100
- });
101
- });
102
-
103
- // Common tests suite.
104
- commonTestsSuite(setup, { className: 'tooltip', prop: 'tooltip' }, { className: CLASSNAME });
105
- });
@@ -1,122 +0,0 @@
1
- /* eslint-disable react-hooks/rules-of-hooks */
2
- import React, { forwardRef, ReactNode, useMemo, useState } from 'react';
3
- import { createPortal } from 'react-dom';
4
- import { usePopper } from 'react-popper';
5
- import { uid } from 'uid';
6
-
7
- import classNames from 'classnames';
8
-
9
- import { Placement } from '@lumx/react/components/popover/Popover';
10
-
11
- import { DOCUMENT } from '@lumx/react/constants';
12
-
13
- import { Comp, GenericProps } from '@lumx/react/utils/type';
14
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
15
- import { mergeRefs } from '@lumx/react/utils/mergeRefs';
16
-
17
- import { useInjectTooltipRef } from './useInjectTooltipRef';
18
- import { useTooltipOpen } from './useTooltipOpen';
19
-
20
- /** Position of the tooltip relative to the anchor element. */
21
- export type TooltipPlacement = Extract<Placement, 'top' | 'right' | 'bottom' | 'left'>;
22
-
23
- /**
24
- * Defines the props of the component.
25
- */
26
- export interface TooltipProps extends GenericProps {
27
- /** Anchor (element on which we activate the tooltip). */
28
- children: ReactNode;
29
- /** Delay (in ms) before closing the tooltip. */
30
- delay?: number;
31
- /** Whether the tooltip is displayed even without the mouse hovering the anchor. */
32
- forceOpen?: boolean;
33
- /** Label text. */
34
- label?: string | null | false;
35
- /** Placement of the tooltip relative to the anchor. */
36
- placement?: TooltipPlacement;
37
- }
38
-
39
- /**
40
- * Component display name.
41
- */
42
- const COMPONENT_NAME = 'Tooltip';
43
-
44
- /**
45
- * Component default class name and class prefix.
46
- */
47
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
48
-
49
- /**
50
- * Component default props.
51
- */
52
- const DEFAULT_PROPS: Partial<TooltipProps> = {
53
- placement: Placement.BOTTOM,
54
- };
55
-
56
- /**
57
- * Arrow size (in pixel).
58
- */
59
- const ARROW_SIZE = 8;
60
-
61
- /**
62
- * Tooltip component.
63
- *
64
- * @param props Component props.
65
- * @param ref Component ref.
66
- * @return React element.
67
- */
68
- export const Tooltip: Comp<TooltipProps, HTMLDivElement> = forwardRef((props, ref) => {
69
- const { label, children, className, delay, placement, forceOpen, ...forwardedProps } = props;
70
- // Disable in SSR or without a label.
71
- if (!DOCUMENT || !label) {
72
- return <>{children}</>;
73
- }
74
-
75
- const id = useMemo(() => `tooltip-${uid()}`, []);
76
-
77
- const [popperElement, setPopperElement] = useState<null | HTMLElement>(null);
78
- const [anchorElement, setAnchorElement] = useState<null | HTMLElement>(null);
79
- const { styles, attributes } = usePopper(anchorElement, popperElement, {
80
- placement,
81
- modifiers: [
82
- {
83
- name: 'offset',
84
- options: { offset: [0, ARROW_SIZE] },
85
- },
86
- ],
87
- });
88
-
89
- const position = attributes?.popper?.['data-popper-placement'] ?? placement;
90
- const isOpen = useTooltipOpen(delay, anchorElement) || forceOpen;
91
- const wrappedChildren = useInjectTooltipRef(children, setAnchorElement, isOpen as boolean, id);
92
-
93
- return (
94
- <>
95
- {wrappedChildren}
96
- {isOpen &&
97
- createPortal(
98
- <div
99
- ref={mergeRefs(ref, setPopperElement)}
100
- {...forwardedProps}
101
- id={id}
102
- role="tooltip"
103
- aria-label={label}
104
- className={classNames(className, handleBasicClasses({ prefix: CLASSNAME, position }))}
105
- style={styles.popper}
106
- {...attributes.popper}
107
- >
108
- <div className={`${CLASSNAME}__arrow`} />
109
- <div className={`${CLASSNAME}__inner`}>
110
- {label.indexOf('\n') !== -1
111
- ? label.split('\n').map((sentence: string) => <p key={sentence}>{sentence}</p>)
112
- : label}
113
- </div>
114
- </div>,
115
- document.body,
116
- )}
117
- </>
118
- );
119
- });
120
- Tooltip.displayName = COMPONENT_NAME;
121
- Tooltip.className = CLASSNAME;
122
- Tooltip.defaultProps = DEFAULT_PROPS;
@@ -1,233 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`<Tooltip> Snapshots and structure should not wrap Button 1`] = `
4
- <Fragment>
5
- <Button
6
- aria-describedby="tooltip-uid"
7
- emphasis="high"
8
- size="m"
9
- theme="light"
10
- >
11
- button
12
- </Button>
13
- <Portal
14
- containerInfo={<body />}
15
- >
16
- <div
17
- aria-label="tooltip1"
18
- className="lumx-tooltip lumx-tooltip--position-bottom"
19
- id="tooltip-uid"
20
- role="tooltip"
21
- style={
22
- {
23
- "left": "0",
24
- "position": "absolute",
25
- "top": "0",
26
- }
27
- }
28
- >
29
- <div
30
- className="lumx-tooltip__arrow"
31
- />
32
- <div
33
- className="lumx-tooltip__inner"
34
- >
35
- tooltip1
36
- </div>
37
- </div>
38
- </Portal>
39
- </Fragment>
40
- `;
41
-
42
- exports[`<Tooltip> Snapshots and structure should not wrap Icon 1`] = `
43
- <Fragment>
44
- <Icon
45
- aria-describedby="tooltip-uid"
46
- icon="icon"
47
- />
48
- <Portal
49
- containerInfo={<body />}
50
- >
51
- <div
52
- aria-label="tooltip1"
53
- className="lumx-tooltip lumx-tooltip--position-bottom"
54
- id="tooltip-uid"
55
- role="tooltip"
56
- style={
57
- {
58
- "left": "0",
59
- "position": "absolute",
60
- "top": "0",
61
- }
62
- }
63
- >
64
- <div
65
- className="lumx-tooltip__arrow"
66
- />
67
- <div
68
- className="lumx-tooltip__inner"
69
- >
70
- tooltip1
71
- </div>
72
- </div>
73
- </Portal>
74
- </Fragment>
75
- `;
76
-
77
- exports[`<Tooltip> Snapshots and structure should render correctly 1`] = `
78
- <Fragment>
79
- <div
80
- aria-describedby="tooltip-uid"
81
- className="lumx-tooltip-anchor-wrapper"
82
- >
83
- Anchor
84
- </div>
85
- <Portal
86
- containerInfo={<body />}
87
- >
88
- <div
89
- aria-label="Tooltip"
90
- className="lumx-tooltip lumx-tooltip--position-bottom"
91
- id="tooltip-uid"
92
- role="tooltip"
93
- style={
94
- {
95
- "left": "0",
96
- "position": "absolute",
97
- "top": "0",
98
- }
99
- }
100
- >
101
- <div
102
- className="lumx-tooltip__arrow"
103
- />
104
- <div
105
- className="lumx-tooltip__inner"
106
- >
107
- Tooltip
108
- </div>
109
- </div>
110
- </Portal>
111
- </Fragment>
112
- `;
113
-
114
- exports[`<Tooltip> Snapshots and structure should return children when empty label 1`] = `
115
- <Fragment>
116
- <Icon
117
- icon="icon"
118
- />
119
- </Fragment>
120
- `;
121
-
122
- exports[`<Tooltip> Snapshots and structure should work on disabled elements 1`] = `
123
- <Fragment>
124
- <div
125
- aria-describedby="tooltip-uid"
126
- className="lumx-tooltip-anchor-wrapper"
127
- >
128
- <Button
129
- emphasis="high"
130
- isDisabled={true}
131
- size="m"
132
- theme="light"
133
- >
134
- Empty
135
- </Button>
136
- </div>
137
- <Portal
138
- containerInfo={<body />}
139
- >
140
- <div
141
- aria-label="Tooltip on disabled button"
142
- className="lumx-tooltip lumx-tooltip--position-bottom"
143
- id="tooltip-uid"
144
- role="tooltip"
145
- style={
146
- {
147
- "left": "0",
148
- "position": "absolute",
149
- "top": "0",
150
- }
151
- }
152
- >
153
- <div
154
- className="lumx-tooltip__arrow"
155
- />
156
- <div
157
- className="lumx-tooltip__inner"
158
- >
159
- Tooltip on disabled button
160
- </div>
161
- </div>
162
- </Portal>
163
- </Fragment>
164
- `;
165
-
166
- exports[`<Tooltip> Snapshots and structure should wrap children 1`] = `
167
- <Fragment>
168
- <div
169
- aria-describedby="tooltip-uid"
170
- className="lumx-tooltip-anchor-wrapper"
171
- >
172
- children
173
- </div>
174
- <Portal
175
- containerInfo={<body />}
176
- >
177
- <div
178
- aria-label="tooltip1"
179
- className="lumx-tooltip lumx-tooltip--position-bottom"
180
- id="tooltip-uid"
181
- role="tooltip"
182
- style={
183
- {
184
- "left": "0",
185
- "position": "absolute",
186
- "top": "0",
187
- }
188
- }
189
- >
190
- <div
191
- className="lumx-tooltip__arrow"
192
- />
193
- <div
194
- className="lumx-tooltip__inner"
195
- >
196
- tooltip1
197
- </div>
198
- </div>
199
- </Portal>
200
- </Fragment>
201
- `;
202
-
203
- exports[`<Tooltip> Snapshots and structure should wrap children 2`] = `
204
- <Fragment>
205
- children
206
- <Portal
207
- containerInfo={<body />}
208
- >
209
- <div
210
- aria-label="tooltip1"
211
- className="lumx-tooltip lumx-tooltip--position-bottom"
212
- id="tooltip-uid"
213
- role="tooltip"
214
- style={
215
- {
216
- "left": "0",
217
- "position": "absolute",
218
- "top": "0",
219
- }
220
- }
221
- >
222
- <div
223
- className="lumx-tooltip__arrow"
224
- />
225
- <div
226
- className="lumx-tooltip__inner"
227
- >
228
- tooltip1
229
- </div>
230
- </div>
231
- </Portal>
232
- </Fragment>
233
- `;
@@ -1 +0,0 @@
1
- export * from './Tooltip';