@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.
Files changed (500) 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} +5 -5
  7. package/{dist/index.js → index.js} +4 -4
  8. package/{dist/index.js.map → index.js.map} +1 -1
  9. package/package.json +3 -3
  10. package/src/components/expansion-panel/ExpansionPanel.stories.tsx +65 -0
  11. package/src/components/expansion-panel/ExpansionPanel.test.tsx +2 -2
  12. package/src/components/expansion-panel/ExpansionPanel.tsx +8 -8
  13. package/{dist/utils → utils}/index.d.ts +0 -0
  14. package/{dist/utils → utils}/index.js +0 -0
  15. package/{dist/utils → utils}/index.js.map +0 -0
  16. package/dist/README.md +0 -38
  17. package/dist/package.json +0 -117
  18. package/dist/src/components/alert-dialog/AlertDialog.stories.tsx +0 -196
  19. package/dist/src/components/alert-dialog/AlertDialog.test.tsx +0 -43
  20. package/dist/src/components/alert-dialog/AlertDialog.tsx +0 -185
  21. package/dist/src/components/alert-dialog/__snapshots__/AlertDialog.test.tsx.snap +0 -551
  22. package/dist/src/components/alert-dialog/index.ts +0 -1
  23. package/dist/src/components/autocomplete/Autocomplete.stories.tsx +0 -70
  24. package/dist/src/components/autocomplete/Autocomplete.test.tsx +0 -181
  25. package/dist/src/components/autocomplete/Autocomplete.tsx +0 -292
  26. package/dist/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -170
  27. package/dist/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -94
  28. package/dist/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
  29. package/dist/src/components/autocomplete/__mockData__/index.ts +0 -34
  30. package/dist/src/components/autocomplete/__snapshots__/Autocomplete.test.tsx.snap +0 -213
  31. package/dist/src/components/autocomplete/__snapshots__/AutocompleteMultiple.test.tsx.snap +0 -88
  32. package/dist/src/components/autocomplete/index.ts +0 -2
  33. package/dist/src/components/avatar/Avatar.stories.tsx +0 -92
  34. package/dist/src/components/avatar/Avatar.test.tsx +0 -39
  35. package/dist/src/components/avatar/Avatar.tsx +0 -112
  36. package/dist/src/components/avatar/__snapshots__/Avatar.test.tsx.snap +0 -681
  37. package/dist/src/components/avatar/index.ts +0 -1
  38. package/dist/src/components/badge/Badge.stories.tsx +0 -45
  39. package/dist/src/components/badge/Badge.test.tsx +0 -91
  40. package/dist/src/components/badge/Badge.tsx +0 -55
  41. package/dist/src/components/badge/__snapshots__/Badge.test.tsx.snap +0 -11
  42. package/dist/src/components/badge/index.ts +0 -1
  43. package/dist/src/components/button/Button.stories.tsx +0 -156
  44. package/dist/src/components/button/Button.test.tsx +0 -152
  45. package/dist/src/components/button/Button.tsx +0 -81
  46. package/dist/src/components/button/ButtonGroup.test.tsx +0 -66
  47. package/dist/src/components/button/ButtonGroup.tsx +0 -46
  48. package/dist/src/components/button/ButtonRoot.test.tsx +0 -203
  49. package/dist/src/components/button/ButtonRoot.tsx +0 -190
  50. package/dist/src/components/button/IconButton.test.tsx +0 -103
  51. package/dist/src/components/button/IconButton.tsx +0 -80
  52. package/dist/src/components/button/__snapshots__/Button.test.tsx.snap +0 -96
  53. package/dist/src/components/button/__snapshots__/ButtonGroup.test.tsx.snap +0 -22
  54. package/dist/src/components/button/__snapshots__/ButtonRoot.test.tsx.snap +0 -160
  55. package/dist/src/components/button/__snapshots__/IconButton.test.tsx.snap +0 -83
  56. package/dist/src/components/button/index.ts +0 -4
  57. package/dist/src/components/checkbox/Checkbox.stories.tsx +0 -37
  58. package/dist/src/components/checkbox/Checkbox.test.tsx +0 -114
  59. package/dist/src/components/checkbox/Checkbox.tsx +0 -145
  60. package/dist/src/components/checkbox/__snapshots__/Checkbox.test.tsx.snap +0 -141
  61. package/dist/src/components/checkbox/index.ts +0 -1
  62. package/dist/src/components/chip/Chip.stories.tsx +0 -21
  63. package/dist/src/components/chip/Chip.test.tsx +0 -199
  64. package/dist/src/components/chip/Chip.tsx +0 -154
  65. package/dist/src/components/chip/ChipGroup.test.tsx +0 -29
  66. package/dist/src/components/chip/ChipGroup.tsx +0 -62
  67. package/dist/src/components/chip/__snapshots__/Chip.test.tsx.snap +0 -12
  68. package/dist/src/components/chip/__snapshots__/ChipGroup.test.tsx.snap +0 -29
  69. package/dist/src/components/chip/index.ts +0 -2
  70. package/dist/src/components/comment-block/CommentBlock.stories.tsx +0 -30
  71. package/dist/src/components/comment-block/CommentBlock.test.tsx +0 -28
  72. package/dist/src/components/comment-block/CommentBlock.tsx +0 -174
  73. package/dist/src/components/comment-block/__snapshots__/CommentBlock.test.tsx.snap +0 -92
  74. package/dist/src/components/comment-block/index.ts +0 -1
  75. package/dist/src/components/date-picker/DatePicker.test.tsx +0 -41
  76. package/dist/src/components/date-picker/DatePicker.tsx +0 -56
  77. package/dist/src/components/date-picker/DatePickerControlled.test.tsx +0 -44
  78. package/dist/src/components/date-picker/DatePickerControlled.tsx +0 -128
  79. package/dist/src/components/date-picker/DatePickerField.stories.tsx +0 -93
  80. package/dist/src/components/date-picker/DatePickerField.test.tsx +0 -47
  81. package/dist/src/components/date-picker/DatePickerField.tsx +0 -141
  82. package/dist/src/components/date-picker/__snapshots__/DatePicker.test.tsx.snap +0 -22
  83. package/dist/src/components/date-picker/__snapshots__/DatePickerControlled.test.tsx.snap +0 -597
  84. package/dist/src/components/date-picker/__snapshots__/DatePickerField.test.tsx.snap +0 -43
  85. package/dist/src/components/date-picker/constants.ts +0 -11
  86. package/dist/src/components/date-picker/index.ts +0 -4
  87. package/dist/src/components/date-picker/types.ts +0 -28
  88. package/dist/src/components/dialog/Dialog.stories.tsx +0 -426
  89. package/dist/src/components/dialog/Dialog.test.tsx +0 -93
  90. package/dist/src/components/dialog/Dialog.tsx +0 -263
  91. package/dist/src/components/dialog/__snapshots__/Dialog.test.tsx.snap +0 -960
  92. package/dist/src/components/dialog/index.ts +0 -1
  93. package/dist/src/components/divider/Divider.test.tsx +0 -93
  94. package/dist/src/components/divider/Divider.tsx +0 -51
  95. package/dist/src/components/divider/__snapshots__/Divider.test.tsx.snap +0 -9
  96. package/dist/src/components/divider/index.ts +0 -1
  97. package/dist/src/components/drag-handle/DragHandle.tsx +0 -50
  98. package/dist/src/components/drag-handle/index.ts +0 -1
  99. package/dist/src/components/dropdown/Dropdown.stories.tsx +0 -216
  100. package/dist/src/components/dropdown/Dropdown.test.tsx +0 -97
  101. package/dist/src/components/dropdown/Dropdown.tsx +0 -184
  102. package/dist/src/components/dropdown/__snapshots__/Dropdown.test.tsx.snap +0 -35
  103. package/dist/src/components/dropdown/index.ts +0 -1
  104. package/dist/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -116
  105. package/dist/src/components/expansion-panel/ExpansionPanel.tsx +0 -170
  106. package/dist/src/components/expansion-panel/index.ts +0 -1
  107. package/dist/src/components/flag/Flag.stories.tsx +0 -23
  108. package/dist/src/components/flag/Flag.test.tsx +0 -86
  109. package/dist/src/components/flag/Flag.tsx +0 -47
  110. package/dist/src/components/flag/__snapshots__/Flag.test.tsx.snap +0 -133
  111. package/dist/src/components/flag/index.ts +0 -1
  112. package/dist/src/components/flex-box/FlexBox.stories.tsx +0 -245
  113. package/dist/src/components/flex-box/FlexBox.test.tsx +0 -65
  114. package/dist/src/components/flex-box/FlexBox.tsx +0 -98
  115. package/dist/src/components/flex-box/__snapshots__/FlexBox.test.tsx.snap +0 -492
  116. package/dist/src/components/flex-box/index.ts +0 -1
  117. package/dist/src/components/generic-block/GenericBlock.stories.jsx +0 -128
  118. package/dist/src/components/generic-block/GenericBlock.test.tsx +0 -152
  119. package/dist/src/components/generic-block/GenericBlock.tsx +0 -222
  120. package/dist/src/components/generic-block/constants.ts +0 -9
  121. package/dist/src/components/generic-block/index.ts +0 -2
  122. package/dist/src/components/grid/Grid.tsx +0 -73
  123. package/dist/src/components/grid/GridItem.tsx +0 -54
  124. package/dist/src/components/grid/index.ts +0 -2
  125. package/dist/src/components/grid-column/GridColumn.stories.jsx +0 -56
  126. package/dist/src/components/grid-column/GridColumn.test.jsx +0 -58
  127. package/dist/src/components/grid-column/GridColumn.tsx +0 -90
  128. package/dist/src/components/grid-column/index.ts +0 -1
  129. package/dist/src/components/heading/Heading.stories.tsx +0 -108
  130. package/dist/src/components/heading/Heading.test.tsx +0 -82
  131. package/dist/src/components/heading/Heading.tsx +0 -63
  132. package/dist/src/components/heading/HeadingLevelProvider.tsx +0 -30
  133. package/dist/src/components/heading/constants.ts +0 -16
  134. package/dist/src/components/heading/context.tsx +0 -13
  135. package/dist/src/components/heading/index.ts +0 -3
  136. package/dist/src/components/heading/useHeadingLevel.tsx +0 -8
  137. package/dist/src/components/icon/Icon.stories.tsx +0 -76
  138. package/dist/src/components/icon/Icon.test.tsx +0 -102
  139. package/dist/src/components/icon/Icon.tsx +0 -121
  140. package/dist/src/components/icon/__snapshots__/Icon.test.tsx.snap +0 -49
  141. package/dist/src/components/icon/index.ts +0 -1
  142. package/dist/src/components/image-block/ImageBlock.stories.tsx +0 -52
  143. package/dist/src/components/image-block/ImageBlock.test.tsx +0 -28
  144. package/dist/src/components/image-block/ImageBlock.tsx +0 -151
  145. package/dist/src/components/image-block/__snapshots__/ImageBlock.test.tsx.snap +0 -64
  146. package/dist/src/components/image-block/index.ts +0 -1
  147. package/dist/src/components/index.ts +0 -176
  148. package/dist/src/components/inline-list/InlineList.stories.tsx +0 -40
  149. package/dist/src/components/inline-list/InlineList.test.tsx +0 -41
  150. package/dist/src/components/inline-list/InlineList.tsx +0 -82
  151. package/dist/src/components/inline-list/index.ts +0 -1
  152. package/dist/src/components/input-helper/InputHelper.stories.tsx +0 -29
  153. package/dist/src/components/input-helper/InputHelper.test.tsx +0 -107
  154. package/dist/src/components/input-helper/InputHelper.tsx +0 -61
  155. package/dist/src/components/input-helper/__snapshots__/InputHelper.test.tsx.snap +0 -9
  156. package/dist/src/components/input-helper/constants.ts +0 -11
  157. package/dist/src/components/input-helper/index.ts +0 -1
  158. package/dist/src/components/input-label/InputLabel.stories.tsx +0 -15
  159. package/dist/src/components/input-label/InputLabel.test.tsx +0 -86
  160. package/dist/src/components/input-label/InputLabel.tsx +0 -59
  161. package/dist/src/components/input-label/__snapshots__/InputLabel.test.tsx.snap +0 -10
  162. package/dist/src/components/input-label/index.ts +0 -1
  163. package/dist/src/components/lightbox/Lightbox.stories.tsx +0 -83
  164. package/dist/src/components/lightbox/Lightbox.test.tsx +0 -30
  165. package/dist/src/components/lightbox/Lightbox.tsx +0 -153
  166. package/dist/src/components/lightbox/__snapshots__/Lightbox.test.tsx.snap +0 -194
  167. package/dist/src/components/lightbox/index.ts +0 -1
  168. package/dist/src/components/link/Link.stories.tsx +0 -141
  169. package/dist/src/components/link/Link.test.tsx +0 -60
  170. package/dist/src/components/link/Link.tsx +0 -156
  171. package/dist/src/components/link/__snapshots__/Link.test.tsx.snap +0 -29
  172. package/dist/src/components/link/index.ts +0 -1
  173. package/dist/src/components/link-preview/LinkPreview.stories.tsx +0 -88
  174. package/dist/src/components/link-preview/LinkPreview.test.tsx +0 -102
  175. package/dist/src/components/link-preview/LinkPreview.tsx +0 -158
  176. package/dist/src/components/link-preview/index.ts +0 -1
  177. package/dist/src/components/list/List.stories.tsx +0 -141
  178. package/dist/src/components/list/List.test.tsx +0 -29
  179. package/dist/src/components/list/List.tsx +0 -94
  180. package/dist/src/components/list/ListDivider.stories.tsx +0 -7
  181. package/dist/src/components/list/ListDivider.test.tsx +0 -29
  182. package/dist/src/components/list/ListDivider.tsx +0 -42
  183. package/dist/src/components/list/ListItem.stories.tsx +0 -62
  184. package/dist/src/components/list/ListItem.test.tsx +0 -29
  185. package/dist/src/components/list/ListItem.tsx +0 -154
  186. package/dist/src/components/list/ListSubheader.stories.tsx +0 -8
  187. package/dist/src/components/list/ListSubheader.test.tsx +0 -29
  188. package/dist/src/components/list/ListSubheader.tsx +0 -43
  189. package/dist/src/components/list/__snapshots__/List.test.tsx.snap +0 -360
  190. package/dist/src/components/list/__snapshots__/ListDivider.test.tsx.snap +0 -7
  191. package/dist/src/components/list/__snapshots__/ListItem.test.tsx.snap +0 -160
  192. package/dist/src/components/list/__snapshots__/ListSubheader.test.tsx.snap +0 -9
  193. package/dist/src/components/list/index.ts +0 -4
  194. package/dist/src/components/list/useInteractiveList.tsx +0 -202
  195. package/dist/src/components/message/Message.stories.tsx +0 -27
  196. package/dist/src/components/message/Message.test.tsx +0 -76
  197. package/dist/src/components/message/Message.tsx +0 -74
  198. package/dist/src/components/message/__snapshots__/Message.test.tsx.snap +0 -15
  199. package/dist/src/components/message/index.ts +0 -1
  200. package/dist/src/components/mosaic/Mosaic.stories.tsx +0 -85
  201. package/dist/src/components/mosaic/Mosaic.test.tsx +0 -120
  202. package/dist/src/components/mosaic/Mosaic.tsx +0 -95
  203. package/dist/src/components/mosaic/__snapshots__/Mosaic.test.tsx.snap +0 -357
  204. package/dist/src/components/mosaic/index.ts +0 -1
  205. package/dist/src/components/notification/Notification.test.tsx +0 -108
  206. package/dist/src/components/notification/Notification.tsx +0 -130
  207. package/dist/src/components/notification/Notifications.stories.tsx +0 -77
  208. package/dist/src/components/notification/__snapshots__/Notification.test.tsx.snap +0 -34
  209. package/dist/src/components/notification/constants.ts +0 -28
  210. package/dist/src/components/notification/index.ts +0 -1
  211. package/dist/src/components/popover/Popover.stories.tsx +0 -386
  212. package/dist/src/components/popover/Popover.test.tsx +0 -30
  213. package/dist/src/components/popover/Popover.tsx +0 -382
  214. package/dist/src/components/popover/__snapshots__/Popover.test.tsx.snap +0 -343
  215. package/dist/src/components/popover/index.ts +0 -1
  216. package/dist/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -75
  217. package/dist/src/components/popover-dialog/PopoverDialog.test.tsx +0 -65
  218. package/dist/src/components/popover-dialog/PopoverDialog.tsx +0 -65
  219. package/dist/src/components/popover-dialog/index.tsx +0 -1
  220. package/dist/src/components/post-block/PostBlock.test.tsx +0 -28
  221. package/dist/src/components/post-block/PostBlock.tsx +0 -123
  222. package/dist/src/components/post-block/__snapshots__/PostBlock.test.tsx.snap +0 -139
  223. package/dist/src/components/post-block/index.ts +0 -1
  224. package/dist/src/components/progress/Progress.tsx +0 -68
  225. package/dist/src/components/progress/ProgressCircular.stories.tsx +0 -18
  226. package/dist/src/components/progress/ProgressCircular.test.tsx +0 -49
  227. package/dist/src/components/progress/ProgressCircular.tsx +0 -68
  228. package/dist/src/components/progress/ProgressLinear.stories.tsx +0 -8
  229. package/dist/src/components/progress/ProgressLinear.test.tsx +0 -37
  230. package/dist/src/components/progress/ProgressLinear.tsx +0 -52
  231. package/dist/src/components/progress/index.ts +0 -3
  232. package/dist/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
  233. package/dist/src/components/progress-tracker/ProgressTracker.test.tsx +0 -57
  234. package/dist/src/components/progress-tracker/ProgressTracker.tsx +0 -89
  235. package/dist/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -42
  236. package/dist/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -66
  237. package/dist/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -128
  238. package/dist/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
  239. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -73
  240. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -67
  241. package/dist/src/components/progress-tracker/__snapshots__/ProgressTracker.test.tsx.snap +0 -41
  242. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStep.test.tsx.snap +0 -141
  243. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStepPanel.test.tsx.snap +0 -25
  244. package/dist/src/components/progress-tracker/index.ts +0 -4
  245. package/dist/src/components/radio-button/RadioButton.stories.tsx +0 -28
  246. package/dist/src/components/radio-button/RadioButton.test.tsx +0 -123
  247. package/dist/src/components/radio-button/RadioButton.tsx +0 -141
  248. package/dist/src/components/radio-button/RadioGroup.stories.tsx +0 -42
  249. package/dist/src/components/radio-button/RadioGroup.test.tsx +0 -77
  250. package/dist/src/components/radio-button/RadioGroup.tsx +0 -52
  251. package/dist/src/components/radio-button/__snapshots__/RadioButton.test.tsx.snap +0 -113
  252. package/dist/src/components/radio-button/__snapshots__/RadioGroup.test.tsx.snap +0 -26
  253. package/dist/src/components/radio-button/index.ts +0 -2
  254. package/dist/src/components/select/Select.stories.tsx +0 -399
  255. package/dist/src/components/select/Select.test.tsx +0 -359
  256. package/dist/src/components/select/Select.tsx +0 -193
  257. package/dist/src/components/select/SelectMultiple.stories.tsx +0 -227
  258. package/dist/src/components/select/SelectMultiple.test.tsx +0 -405
  259. package/dist/src/components/select/SelectMultiple.tsx +0 -198
  260. package/dist/src/components/select/WithSelectContext.tsx +0 -143
  261. package/dist/src/components/select/__snapshots__/Select.test.tsx.snap +0 -43
  262. package/dist/src/components/select/__snapshots__/SelectMultiple.test.tsx.snap +0 -87
  263. package/dist/src/components/select/constants.ts +0 -53
  264. package/dist/src/components/select/index.ts +0 -2
  265. package/dist/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
  266. package/dist/src/components/side-navigation/SideNavigation.test.tsx +0 -52
  267. package/dist/src/components/side-navigation/SideNavigation.tsx +0 -54
  268. package/dist/src/components/side-navigation/SideNavigationItem.test.tsx +0 -175
  269. package/dist/src/components/side-navigation/SideNavigationItem.tsx +0 -162
  270. package/dist/src/components/side-navigation/__snapshots__/SideNavigation.test.tsx.snap +0 -7
  271. package/dist/src/components/side-navigation/__snapshots__/SideNavigationItem.test.tsx.snap +0 -30
  272. package/dist/src/components/side-navigation/index.ts +0 -2
  273. package/dist/src/components/skeleton/SkeletonCircle.stories.tsx +0 -25
  274. package/dist/src/components/skeleton/SkeletonCircle.test.tsx +0 -28
  275. package/dist/src/components/skeleton/SkeletonCircle.tsx +0 -52
  276. package/dist/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -107
  277. package/dist/src/components/skeleton/SkeletonRectangle.test.tsx +0 -28
  278. package/dist/src/components/skeleton/SkeletonRectangle.tsx +0 -78
  279. package/dist/src/components/skeleton/SkeletonTypography.stories.tsx +0 -26
  280. package/dist/src/components/skeleton/SkeletonTypography.test.tsx +0 -28
  281. package/dist/src/components/skeleton/SkeletonTypography.tsx +0 -57
  282. package/dist/src/components/skeleton/__snapshots__/SkeletonCircle.test.tsx.snap +0 -54
  283. package/dist/src/components/skeleton/__snapshots__/SkeletonRectangle.test.tsx.snap +0 -177
  284. package/dist/src/components/skeleton/__snapshots__/SkeletonTypography.test.tsx.snap +0 -174
  285. package/dist/src/components/skeleton/index.ts +0 -3
  286. package/dist/src/components/slider/Slider.stories.tsx +0 -29
  287. package/dist/src/components/slider/Slider.test.tsx +0 -31
  288. package/dist/src/components/slider/Slider.tsx +0 -299
  289. package/dist/src/components/slider/__snapshots__/Slider.test.tsx.snap +0 -122
  290. package/dist/src/components/slider/index.ts +0 -2
  291. package/dist/src/components/slideshow/Slides.tsx +0 -124
  292. package/dist/src/components/slideshow/Slideshow.stories.tsx +0 -212
  293. package/dist/src/components/slideshow/Slideshow.test.tsx +0 -39
  294. package/dist/src/components/slideshow/Slideshow.tsx +0 -170
  295. package/dist/src/components/slideshow/SlideshowControls.stories.tsx +0 -112
  296. package/dist/src/components/slideshow/SlideshowControls.tsx +0 -241
  297. package/dist/src/components/slideshow/SlideshowItem.tsx +0 -52
  298. package/dist/src/components/slideshow/SlideshowItemGroup.tsx +0 -64
  299. package/dist/src/components/slideshow/__snapshots__/Slideshow.test.tsx.snap +0 -157
  300. package/dist/src/components/slideshow/constants.ts +0 -24
  301. package/dist/src/components/slideshow/index.ts +0 -4
  302. package/dist/src/components/slideshow/useKeyNavigate.ts +0 -28
  303. package/dist/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
  304. package/dist/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
  305. package/dist/src/components/slideshow/useSwipeNavigate.ts +0 -18
  306. package/dist/src/components/switch/Switch.stories.tsx +0 -36
  307. package/dist/src/components/switch/Switch.test.tsx +0 -189
  308. package/dist/src/components/switch/Switch.tsx +0 -141
  309. package/dist/src/components/switch/__snapshots__/Switch.test.tsx.snap +0 -179
  310. package/dist/src/components/switch/index.ts +0 -1
  311. package/dist/src/components/table/Table.test.tsx +0 -28
  312. package/dist/src/components/table/Table.tsx +0 -59
  313. package/dist/src/components/table/TableBody.test.tsx +0 -22
  314. package/dist/src/components/table/TableBody.tsx +0 -44
  315. package/dist/src/components/table/TableCell.test.tsx +0 -23
  316. package/dist/src/components/table/TableCell.tsx +0 -125
  317. package/dist/src/components/table/TableHeader.test.tsx +0 -22
  318. package/dist/src/components/table/TableHeader.tsx +0 -50
  319. package/dist/src/components/table/TableRow.test.tsx +0 -22
  320. package/dist/src/components/table/TableRow.tsx +0 -68
  321. package/dist/src/components/table/__snapshots__/Table.test.tsx.snap +0 -263
  322. package/dist/src/components/table/index.ts +0 -5
  323. package/dist/src/components/tabs/Tab.test.tsx +0 -116
  324. package/dist/src/components/tabs/Tab.tsx +0 -120
  325. package/dist/src/components/tabs/TabList.test.tsx +0 -80
  326. package/dist/src/components/tabs/TabList.tsx +0 -82
  327. package/dist/src/components/tabs/TabPanel.test.tsx +0 -74
  328. package/dist/src/components/tabs/TabPanel.tsx +0 -65
  329. package/dist/src/components/tabs/TabProvider.test.tsx +0 -42
  330. package/dist/src/components/tabs/TabProvider.tsx +0 -59
  331. package/dist/src/components/tabs/Tabs.stories.tsx +0 -134
  332. package/dist/src/components/tabs/__snapshots__/Tab.test.tsx.snap +0 -62
  333. package/dist/src/components/tabs/__snapshots__/TabList.test.tsx.snap +0 -22
  334. package/dist/src/components/tabs/__snapshots__/TabPanel.test.tsx.snap +0 -25
  335. package/dist/src/components/tabs/index.ts +0 -4
  336. package/dist/src/components/tabs/state.ts +0 -116
  337. package/dist/src/components/tabs/test.mocks.ts +0 -33
  338. package/dist/src/components/text/Text.stories.jsx +0 -75
  339. package/dist/src/components/text/Text.test.tsx +0 -108
  340. package/dist/src/components/text/Text.tsx +0 -121
  341. package/dist/src/components/text/index.ts +0 -1
  342. package/dist/src/components/text-field/TextField.stories.tsx +0 -169
  343. package/dist/src/components/text-field/TextField.test.tsx +0 -171
  344. package/dist/src/components/text-field/TextField.tsx +0 -432
  345. package/dist/src/components/text-field/__snapshots__/TextField.test.tsx.snap +0 -42
  346. package/dist/src/components/text-field/index.ts +0 -1
  347. package/dist/src/components/thumbnail/Thumbnail.stories.tsx +0 -510
  348. package/dist/src/components/thumbnail/Thumbnail.test.tsx +0 -46
  349. package/dist/src/components/thumbnail/Thumbnail.tsx +0 -222
  350. package/dist/src/components/thumbnail/__snapshots__/Thumbnail.test.tsx.snap +0 -130
  351. package/dist/src/components/thumbnail/index.ts +0 -3
  352. package/dist/src/components/thumbnail/types.ts +0 -39
  353. package/dist/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
  354. package/dist/src/components/thumbnail/useFocusPointStyle.tsx +0 -111
  355. package/dist/src/components/thumbnail/useImageLoad.ts +0 -40
  356. package/dist/src/components/toolbar/Toolbar.tsx +0 -67
  357. package/dist/src/components/toolbar/index.ts +0 -1
  358. package/dist/src/components/tooltip/Tooltip.stories.tsx +0 -172
  359. package/dist/src/components/tooltip/Tooltip.test.tsx +0 -105
  360. package/dist/src/components/tooltip/Tooltip.tsx +0 -122
  361. package/dist/src/components/tooltip/__snapshots__/Tooltip.test.tsx.snap +0 -233
  362. package/dist/src/components/tooltip/index.ts +0 -1
  363. package/dist/src/components/tooltip/useInjectTooltipRef.tsx +0 -44
  364. package/dist/src/components/tooltip/useTooltipOpen.tsx +0 -113
  365. package/dist/src/components/uploader/Uploader.test.tsx +0 -87
  366. package/dist/src/components/uploader/Uploader.tsx +0 -105
  367. package/dist/src/components/uploader/__snapshots__/Uploader.test.tsx.snap +0 -14
  368. package/dist/src/components/uploader/index.ts +0 -1
  369. package/dist/src/components/user-block/UserBlock.stories.tsx +0 -76
  370. package/dist/src/components/user-block/UserBlock.test.tsx +0 -38
  371. package/dist/src/components/user-block/UserBlock.tsx +0 -179
  372. package/dist/src/components/user-block/__snapshots__/UserBlock.test.tsx.snap +0 -362
  373. package/dist/src/components/user-block/index.ts +0 -1
  374. package/dist/src/constants.ts +0 -17
  375. package/dist/src/hooks/useBooleanState.tsx +0 -13
  376. package/dist/src/hooks/useCallbackOnEscape.ts +0 -34
  377. package/dist/src/hooks/useChipGroupNavigation.tsx +0 -75
  378. package/dist/src/hooks/useClickAway.tsx +0 -47
  379. package/dist/src/hooks/useDisableBodyScroll.ts +0 -28
  380. package/dist/src/hooks/useEventCallback.tsx +0 -17
  381. package/dist/src/hooks/useFocus.tsx +0 -21
  382. package/dist/src/hooks/useFocusTrap.ts +0 -85
  383. package/dist/src/hooks/useFocusWithin.ts +0 -33
  384. package/dist/src/hooks/useInfiniteScroll.tsx +0 -60
  385. package/dist/src/hooks/useIntersectionObserver.tsx +0 -43
  386. package/dist/src/hooks/useInterval.tsx +0 -31
  387. package/dist/src/hooks/useKeyboardListNavigation.tsx +0 -204
  388. package/dist/src/hooks/useListenFocus.tsx +0 -26
  389. package/dist/src/hooks/useOnResize.ts +0 -41
  390. package/dist/src/hooks/useRovingTabIndex.tsx +0 -90
  391. package/dist/src/hooks/useSlideshowControls.ts +0 -243
  392. package/dist/src/hooks/useStopPropagation.ts +0 -21
  393. package/dist/src/hooks/useTransitionVisibility.ts +0 -54
  394. package/dist/src/index.ts +0 -58
  395. package/dist/src/stories/chromaticForceScreenSize.tsx +0 -7
  396. package/dist/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
  397. package/dist/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
  398. package/dist/src/stories/generated/Badge/Demos.stories.tsx +0 -9
  399. package/dist/src/stories/generated/Button/Demos.stories.tsx +0 -11
  400. package/dist/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
  401. package/dist/src/stories/generated/Chip/Demos.stories.tsx +0 -11
  402. package/dist/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
  403. package/dist/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
  404. package/dist/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
  405. package/dist/src/stories/generated/Divider/Demos.stories.tsx +0 -6
  406. package/dist/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
  407. package/dist/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
  408. package/dist/src/stories/generated/Flag/Demos.stories.tsx +0 -6
  409. package/dist/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
  410. package/dist/src/stories/generated/Heading/Demos.stories.tsx +0 -6
  411. package/dist/src/stories/generated/Icon/Demos.stories.tsx +0 -8
  412. package/dist/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
  413. package/dist/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
  414. package/dist/src/stories/generated/Link/Demos.stories.tsx +0 -8
  415. package/dist/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
  416. package/dist/src/stories/generated/List/Demos.stories.tsx +0 -11
  417. package/dist/src/stories/generated/Message/Demos.stories.tsx +0 -10
  418. package/dist/src/stories/generated/Mosaic/Demos.stories.tsx +0 -9
  419. package/dist/src/stories/generated/Notification/Demos.stories.tsx +0 -6
  420. package/dist/src/stories/generated/Popover/Demos.stories.tsx +0 -11
  421. package/dist/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
  422. package/dist/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
  423. package/dist/src/stories/generated/Progress/Demos.stories.tsx +0 -7
  424. package/dist/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
  425. package/dist/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
  426. package/dist/src/stories/generated/Select/Demos.stories.tsx +0 -14
  427. package/dist/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
  428. package/dist/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
  429. package/dist/src/stories/generated/Slider/Demos.stories.tsx +0 -9
  430. package/dist/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
  431. package/dist/src/stories/generated/Switch/Demos.stories.tsx +0 -6
  432. package/dist/src/stories/generated/Table/Demos.stories.tsx +0 -6
  433. package/dist/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
  434. package/dist/src/stories/generated/TextField/Demos.stories.tsx +0 -19
  435. package/dist/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
  436. package/dist/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
  437. package/dist/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
  438. package/dist/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
  439. package/dist/src/stories/generated/UserBlock/Demos.stories.tsx +0 -10
  440. package/dist/src/stories/knobs/buttonKnob.ts +0 -9
  441. package/dist/src/stories/knobs/emphasisKnob.ts +0 -8
  442. package/dist/src/stories/knobs/enumKnob.ts +0 -14
  443. package/dist/src/stories/knobs/focusKnob.ts +0 -3
  444. package/dist/src/stories/knobs/image.ts +0 -69
  445. package/dist/src/stories/knobs/lorem.ts +0 -59
  446. package/dist/src/stories/knobs/sizeKnob.ts +0 -5
  447. package/dist/src/stories/knobs/thumbnailsKnob.ts +0 -9
  448. package/dist/src/stories/utils/CustomLink.tsx +0 -7
  449. package/dist/src/stories/withResizableBox.tsx +0 -18
  450. package/dist/src/testing/utils/commonTestsSuite.ts +0 -71
  451. package/dist/src/testing/utils/commonTestsSuiteRTL.ts +0 -55
  452. package/dist/src/testing/utils/index.ts +0 -4
  453. package/dist/src/testing/utils/itShouldRenderStories.tsx +0 -103
  454. package/dist/src/testing/utils/queries.ts +0 -19
  455. package/dist/src/untypped-modules.d.ts +0 -7
  456. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -58
  457. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -65
  458. package/dist/src/utils/ClickAwayProvider/index.ts +0 -1
  459. package/dist/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
  460. package/dist/src/utils/MaterialThemeSwitcher/index.ts +0 -1
  461. package/dist/src/utils/browserDoesNotSupportHover.test.js +0 -24
  462. package/dist/src/utils/browserDoesNotSupportHover.ts +0 -2
  463. package/dist/src/utils/clamp.ts +0 -17
  464. package/dist/src/utils/className.ts +0 -44
  465. package/dist/src/utils/event.ts +0 -1
  466. package/dist/src/utils/flattenChildren.test.tsx +0 -58
  467. package/dist/src/utils/flattenChildren.ts +0 -27
  468. package/dist/src/utils/focus/constants.ts +0 -5
  469. package/dist/src/utils/focus/getFirstAndLastFocusable.test.ts +0 -134
  470. package/dist/src/utils/focus/getFirstAndLastFocusable.ts +0 -21
  471. package/dist/src/utils/focus/getFocusableElements.test.ts +0 -151
  472. package/dist/src/utils/focus/getFocusableElements.ts +0 -7
  473. package/dist/src/utils/index.ts +0 -5
  474. package/dist/src/utils/isInternetExplorer.ts +0 -15
  475. package/dist/src/utils/makeListenerTowerContext.ts +0 -32
  476. package/dist/src/utils/mergeRefs.ts +0 -22
  477. package/dist/src/utils/partitionMulti.ts +0 -28
  478. package/dist/src/utils/renderLink.tsx +0 -17
  479. package/dist/src/utils/type.ts +0 -113
  480. package/dist/src/utils/userHasReducedMotion.ts +0 -7
  481. package/dist/src/utils/utils.test.ts +0 -48
  482. package/jest/__mocks__/@storybook/addon-actions.js +0 -3
  483. package/jest/__mocks__/@storybook/addon-knobs.js +0 -6
  484. package/jest/__mocks__/emptyFileMockTransformer.js +0 -8
  485. package/jest/__mocks__/emptyModuleMock.js +0 -1
  486. package/jest/configure.js +0 -6
  487. package/jest/index.js +0 -36
  488. package/jest/transform.js +0 -6
  489. package/rollup.config.js +0 -98
  490. package/storybook/build +0 -4
  491. package/storybook/generate-demo-stories.js +0 -59
  492. package/storybook/main.js +0 -67
  493. package/storybook/package.json +0 -13
  494. package/storybook/preview.js +0 -11
  495. package/storybook/start +0 -4
  496. package/storybook/story-block/StoryBlock.tsx +0 -49
  497. package/storybook/story-block/decorator.jsx +0 -7
  498. package/storybook/story-block/index.scss +0 -27
  499. package/storybook/yarn.lock +0 -13192
  500. 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';