@lumx/react 3.1.1 → 3.1.2

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