@lumx/react 3.0.7-alpha.3 → 3.0.7-alpha.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (502) hide show
  1. package/{dist/CONTRIBUTING.md → CONTRIBUTING.md} +0 -0
  2. package/{dist/LICENSE.md → LICENSE.md} +0 -0
  3. package/{dist/_internal → _internal}/ClickAwayProvider.js +0 -0
  4. package/{dist/_internal → _internal}/ClickAwayProvider.js.map +0 -0
  5. package/{dist/_internal → _internal}/types.d.ts +1 -1
  6. package/{dist/index.d.ts → index.d.ts} +7 -7
  7. package/{dist/index.js → index.js} +0 -0
  8. package/{dist/index.js.map → index.js.map} +1 -1
  9. package/package.json +3 -3
  10. package/src/components/badge/Badge.tsx +2 -2
  11. package/src/components/button/ButtonRoot.tsx +2 -2
  12. package/src/components/chip/Chip.tsx +2 -2
  13. package/src/components/icon/Icon.tsx +2 -2
  14. package/src/components/link/Link.tsx +2 -2
  15. package/{dist/utils → utils}/index.d.ts +0 -0
  16. package/{dist/utils → utils}/index.js +0 -0
  17. package/{dist/utils → utils}/index.js.map +0 -0
  18. package/dist/README.md +0 -38
  19. package/dist/package.json +0 -117
  20. package/dist/src/components/alert-dialog/AlertDialog.stories.tsx +0 -196
  21. package/dist/src/components/alert-dialog/AlertDialog.test.tsx +0 -43
  22. package/dist/src/components/alert-dialog/AlertDialog.tsx +0 -185
  23. package/dist/src/components/alert-dialog/__snapshots__/AlertDialog.test.tsx.snap +0 -551
  24. package/dist/src/components/alert-dialog/index.ts +0 -1
  25. package/dist/src/components/autocomplete/Autocomplete.stories.tsx +0 -70
  26. package/dist/src/components/autocomplete/Autocomplete.test.tsx +0 -181
  27. package/dist/src/components/autocomplete/Autocomplete.tsx +0 -292
  28. package/dist/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -170
  29. package/dist/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -94
  30. package/dist/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
  31. package/dist/src/components/autocomplete/__mockData__/index.ts +0 -34
  32. package/dist/src/components/autocomplete/__snapshots__/Autocomplete.test.tsx.snap +0 -213
  33. package/dist/src/components/autocomplete/__snapshots__/AutocompleteMultiple.test.tsx.snap +0 -88
  34. package/dist/src/components/autocomplete/index.ts +0 -2
  35. package/dist/src/components/avatar/Avatar.stories.tsx +0 -92
  36. package/dist/src/components/avatar/Avatar.test.tsx +0 -39
  37. package/dist/src/components/avatar/Avatar.tsx +0 -112
  38. package/dist/src/components/avatar/__snapshots__/Avatar.test.tsx.snap +0 -681
  39. package/dist/src/components/avatar/index.ts +0 -1
  40. package/dist/src/components/badge/Badge.stories.tsx +0 -45
  41. package/dist/src/components/badge/Badge.test.tsx +0 -91
  42. package/dist/src/components/badge/Badge.tsx +0 -55
  43. package/dist/src/components/badge/__snapshots__/Badge.test.tsx.snap +0 -11
  44. package/dist/src/components/badge/index.ts +0 -1
  45. package/dist/src/components/button/Button.stories.tsx +0 -156
  46. package/dist/src/components/button/Button.test.tsx +0 -152
  47. package/dist/src/components/button/Button.tsx +0 -81
  48. package/dist/src/components/button/ButtonGroup.test.tsx +0 -66
  49. package/dist/src/components/button/ButtonGroup.tsx +0 -46
  50. package/dist/src/components/button/ButtonRoot.test.tsx +0 -203
  51. package/dist/src/components/button/ButtonRoot.tsx +0 -190
  52. package/dist/src/components/button/IconButton.test.tsx +0 -103
  53. package/dist/src/components/button/IconButton.tsx +0 -80
  54. package/dist/src/components/button/__snapshots__/Button.test.tsx.snap +0 -96
  55. package/dist/src/components/button/__snapshots__/ButtonGroup.test.tsx.snap +0 -22
  56. package/dist/src/components/button/__snapshots__/ButtonRoot.test.tsx.snap +0 -160
  57. package/dist/src/components/button/__snapshots__/IconButton.test.tsx.snap +0 -83
  58. package/dist/src/components/button/index.ts +0 -4
  59. package/dist/src/components/checkbox/Checkbox.stories.tsx +0 -37
  60. package/dist/src/components/checkbox/Checkbox.test.tsx +0 -114
  61. package/dist/src/components/checkbox/Checkbox.tsx +0 -145
  62. package/dist/src/components/checkbox/__snapshots__/Checkbox.test.tsx.snap +0 -141
  63. package/dist/src/components/checkbox/index.ts +0 -1
  64. package/dist/src/components/chip/Chip.stories.tsx +0 -21
  65. package/dist/src/components/chip/Chip.test.tsx +0 -199
  66. package/dist/src/components/chip/Chip.tsx +0 -154
  67. package/dist/src/components/chip/ChipGroup.test.tsx +0 -29
  68. package/dist/src/components/chip/ChipGroup.tsx +0 -62
  69. package/dist/src/components/chip/__snapshots__/Chip.test.tsx.snap +0 -12
  70. package/dist/src/components/chip/__snapshots__/ChipGroup.test.tsx.snap +0 -29
  71. package/dist/src/components/chip/index.ts +0 -2
  72. package/dist/src/components/comment-block/CommentBlock.stories.tsx +0 -30
  73. package/dist/src/components/comment-block/CommentBlock.test.tsx +0 -28
  74. package/dist/src/components/comment-block/CommentBlock.tsx +0 -174
  75. package/dist/src/components/comment-block/__snapshots__/CommentBlock.test.tsx.snap +0 -92
  76. package/dist/src/components/comment-block/index.ts +0 -1
  77. package/dist/src/components/date-picker/DatePicker.test.tsx +0 -41
  78. package/dist/src/components/date-picker/DatePicker.tsx +0 -56
  79. package/dist/src/components/date-picker/DatePickerControlled.test.tsx +0 -44
  80. package/dist/src/components/date-picker/DatePickerControlled.tsx +0 -128
  81. package/dist/src/components/date-picker/DatePickerField.stories.tsx +0 -93
  82. package/dist/src/components/date-picker/DatePickerField.test.tsx +0 -47
  83. package/dist/src/components/date-picker/DatePickerField.tsx +0 -141
  84. package/dist/src/components/date-picker/__snapshots__/DatePicker.test.tsx.snap +0 -22
  85. package/dist/src/components/date-picker/__snapshots__/DatePickerControlled.test.tsx.snap +0 -597
  86. package/dist/src/components/date-picker/__snapshots__/DatePickerField.test.tsx.snap +0 -43
  87. package/dist/src/components/date-picker/constants.ts +0 -11
  88. package/dist/src/components/date-picker/index.ts +0 -4
  89. package/dist/src/components/date-picker/types.ts +0 -28
  90. package/dist/src/components/dialog/Dialog.stories.tsx +0 -426
  91. package/dist/src/components/dialog/Dialog.test.tsx +0 -93
  92. package/dist/src/components/dialog/Dialog.tsx +0 -263
  93. package/dist/src/components/dialog/__snapshots__/Dialog.test.tsx.snap +0 -960
  94. package/dist/src/components/dialog/index.ts +0 -1
  95. package/dist/src/components/divider/Divider.test.tsx +0 -93
  96. package/dist/src/components/divider/Divider.tsx +0 -51
  97. package/dist/src/components/divider/__snapshots__/Divider.test.tsx.snap +0 -9
  98. package/dist/src/components/divider/index.ts +0 -1
  99. package/dist/src/components/drag-handle/DragHandle.tsx +0 -50
  100. package/dist/src/components/drag-handle/index.ts +0 -1
  101. package/dist/src/components/dropdown/Dropdown.stories.tsx +0 -216
  102. package/dist/src/components/dropdown/Dropdown.test.tsx +0 -97
  103. package/dist/src/components/dropdown/Dropdown.tsx +0 -184
  104. package/dist/src/components/dropdown/__snapshots__/Dropdown.test.tsx.snap +0 -35
  105. package/dist/src/components/dropdown/index.ts +0 -1
  106. package/dist/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -116
  107. package/dist/src/components/expansion-panel/ExpansionPanel.tsx +0 -170
  108. package/dist/src/components/expansion-panel/index.ts +0 -1
  109. package/dist/src/components/flag/Flag.stories.tsx +0 -23
  110. package/dist/src/components/flag/Flag.test.tsx +0 -86
  111. package/dist/src/components/flag/Flag.tsx +0 -47
  112. package/dist/src/components/flag/__snapshots__/Flag.test.tsx.snap +0 -133
  113. package/dist/src/components/flag/index.ts +0 -1
  114. package/dist/src/components/flex-box/FlexBox.stories.tsx +0 -245
  115. package/dist/src/components/flex-box/FlexBox.test.tsx +0 -65
  116. package/dist/src/components/flex-box/FlexBox.tsx +0 -98
  117. package/dist/src/components/flex-box/__snapshots__/FlexBox.test.tsx.snap +0 -492
  118. package/dist/src/components/flex-box/index.ts +0 -1
  119. package/dist/src/components/generic-block/GenericBlock.stories.jsx +0 -128
  120. package/dist/src/components/generic-block/GenericBlock.test.tsx +0 -152
  121. package/dist/src/components/generic-block/GenericBlock.tsx +0 -222
  122. package/dist/src/components/generic-block/constants.ts +0 -9
  123. package/dist/src/components/generic-block/index.ts +0 -2
  124. package/dist/src/components/grid/Grid.tsx +0 -73
  125. package/dist/src/components/grid/GridItem.tsx +0 -54
  126. package/dist/src/components/grid/index.ts +0 -2
  127. package/dist/src/components/grid-column/GridColumn.stories.jsx +0 -56
  128. package/dist/src/components/grid-column/GridColumn.test.jsx +0 -58
  129. package/dist/src/components/grid-column/GridColumn.tsx +0 -90
  130. package/dist/src/components/grid-column/index.ts +0 -1
  131. package/dist/src/components/heading/Heading.stories.tsx +0 -108
  132. package/dist/src/components/heading/Heading.test.tsx +0 -82
  133. package/dist/src/components/heading/Heading.tsx +0 -63
  134. package/dist/src/components/heading/HeadingLevelProvider.tsx +0 -30
  135. package/dist/src/components/heading/constants.ts +0 -16
  136. package/dist/src/components/heading/context.tsx +0 -13
  137. package/dist/src/components/heading/index.ts +0 -3
  138. package/dist/src/components/heading/useHeadingLevel.tsx +0 -8
  139. package/dist/src/components/icon/Icon.stories.tsx +0 -76
  140. package/dist/src/components/icon/Icon.test.tsx +0 -102
  141. package/dist/src/components/icon/Icon.tsx +0 -121
  142. package/dist/src/components/icon/__snapshots__/Icon.test.tsx.snap +0 -49
  143. package/dist/src/components/icon/index.ts +0 -1
  144. package/dist/src/components/image-block/ImageBlock.stories.tsx +0 -52
  145. package/dist/src/components/image-block/ImageBlock.test.tsx +0 -28
  146. package/dist/src/components/image-block/ImageBlock.tsx +0 -151
  147. package/dist/src/components/image-block/__snapshots__/ImageBlock.test.tsx.snap +0 -64
  148. package/dist/src/components/image-block/index.ts +0 -1
  149. package/dist/src/components/index.ts +0 -176
  150. package/dist/src/components/inline-list/InlineList.stories.tsx +0 -40
  151. package/dist/src/components/inline-list/InlineList.test.tsx +0 -41
  152. package/dist/src/components/inline-list/InlineList.tsx +0 -82
  153. package/dist/src/components/inline-list/index.ts +0 -1
  154. package/dist/src/components/input-helper/InputHelper.stories.tsx +0 -29
  155. package/dist/src/components/input-helper/InputHelper.test.tsx +0 -107
  156. package/dist/src/components/input-helper/InputHelper.tsx +0 -61
  157. package/dist/src/components/input-helper/__snapshots__/InputHelper.test.tsx.snap +0 -9
  158. package/dist/src/components/input-helper/constants.ts +0 -11
  159. package/dist/src/components/input-helper/index.ts +0 -1
  160. package/dist/src/components/input-label/InputLabel.stories.tsx +0 -15
  161. package/dist/src/components/input-label/InputLabel.test.tsx +0 -86
  162. package/dist/src/components/input-label/InputLabel.tsx +0 -59
  163. package/dist/src/components/input-label/__snapshots__/InputLabel.test.tsx.snap +0 -10
  164. package/dist/src/components/input-label/index.ts +0 -1
  165. package/dist/src/components/lightbox/Lightbox.stories.tsx +0 -83
  166. package/dist/src/components/lightbox/Lightbox.test.tsx +0 -30
  167. package/dist/src/components/lightbox/Lightbox.tsx +0 -153
  168. package/dist/src/components/lightbox/__snapshots__/Lightbox.test.tsx.snap +0 -194
  169. package/dist/src/components/lightbox/index.ts +0 -1
  170. package/dist/src/components/link/Link.stories.tsx +0 -141
  171. package/dist/src/components/link/Link.test.tsx +0 -60
  172. package/dist/src/components/link/Link.tsx +0 -156
  173. package/dist/src/components/link/__snapshots__/Link.test.tsx.snap +0 -29
  174. package/dist/src/components/link/index.ts +0 -1
  175. package/dist/src/components/link-preview/LinkPreview.stories.tsx +0 -88
  176. package/dist/src/components/link-preview/LinkPreview.test.tsx +0 -102
  177. package/dist/src/components/link-preview/LinkPreview.tsx +0 -158
  178. package/dist/src/components/link-preview/index.ts +0 -1
  179. package/dist/src/components/list/List.stories.tsx +0 -141
  180. package/dist/src/components/list/List.test.tsx +0 -29
  181. package/dist/src/components/list/List.tsx +0 -94
  182. package/dist/src/components/list/ListDivider.stories.tsx +0 -7
  183. package/dist/src/components/list/ListDivider.test.tsx +0 -29
  184. package/dist/src/components/list/ListDivider.tsx +0 -42
  185. package/dist/src/components/list/ListItem.stories.tsx +0 -62
  186. package/dist/src/components/list/ListItem.test.tsx +0 -29
  187. package/dist/src/components/list/ListItem.tsx +0 -154
  188. package/dist/src/components/list/ListSubheader.stories.tsx +0 -8
  189. package/dist/src/components/list/ListSubheader.test.tsx +0 -29
  190. package/dist/src/components/list/ListSubheader.tsx +0 -43
  191. package/dist/src/components/list/__snapshots__/List.test.tsx.snap +0 -360
  192. package/dist/src/components/list/__snapshots__/ListDivider.test.tsx.snap +0 -7
  193. package/dist/src/components/list/__snapshots__/ListItem.test.tsx.snap +0 -160
  194. package/dist/src/components/list/__snapshots__/ListSubheader.test.tsx.snap +0 -9
  195. package/dist/src/components/list/index.ts +0 -4
  196. package/dist/src/components/list/useInteractiveList.tsx +0 -202
  197. package/dist/src/components/message/Message.stories.tsx +0 -27
  198. package/dist/src/components/message/Message.test.tsx +0 -76
  199. package/dist/src/components/message/Message.tsx +0 -74
  200. package/dist/src/components/message/__snapshots__/Message.test.tsx.snap +0 -15
  201. package/dist/src/components/message/index.ts +0 -1
  202. package/dist/src/components/mosaic/Mosaic.stories.tsx +0 -85
  203. package/dist/src/components/mosaic/Mosaic.test.tsx +0 -120
  204. package/dist/src/components/mosaic/Mosaic.tsx +0 -95
  205. package/dist/src/components/mosaic/__snapshots__/Mosaic.test.tsx.snap +0 -357
  206. package/dist/src/components/mosaic/index.ts +0 -1
  207. package/dist/src/components/notification/Notification.test.tsx +0 -108
  208. package/dist/src/components/notification/Notification.tsx +0 -130
  209. package/dist/src/components/notification/Notifications.stories.tsx +0 -77
  210. package/dist/src/components/notification/__snapshots__/Notification.test.tsx.snap +0 -34
  211. package/dist/src/components/notification/constants.ts +0 -28
  212. package/dist/src/components/notification/index.ts +0 -1
  213. package/dist/src/components/popover/Popover.stories.tsx +0 -386
  214. package/dist/src/components/popover/Popover.test.tsx +0 -30
  215. package/dist/src/components/popover/Popover.tsx +0 -382
  216. package/dist/src/components/popover/__snapshots__/Popover.test.tsx.snap +0 -343
  217. package/dist/src/components/popover/index.ts +0 -1
  218. package/dist/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -75
  219. package/dist/src/components/popover-dialog/PopoverDialog.test.tsx +0 -65
  220. package/dist/src/components/popover-dialog/PopoverDialog.tsx +0 -65
  221. package/dist/src/components/popover-dialog/index.tsx +0 -1
  222. package/dist/src/components/post-block/PostBlock.test.tsx +0 -28
  223. package/dist/src/components/post-block/PostBlock.tsx +0 -123
  224. package/dist/src/components/post-block/__snapshots__/PostBlock.test.tsx.snap +0 -139
  225. package/dist/src/components/post-block/index.ts +0 -1
  226. package/dist/src/components/progress/Progress.tsx +0 -68
  227. package/dist/src/components/progress/ProgressCircular.stories.tsx +0 -18
  228. package/dist/src/components/progress/ProgressCircular.test.tsx +0 -49
  229. package/dist/src/components/progress/ProgressCircular.tsx +0 -68
  230. package/dist/src/components/progress/ProgressLinear.stories.tsx +0 -8
  231. package/dist/src/components/progress/ProgressLinear.test.tsx +0 -37
  232. package/dist/src/components/progress/ProgressLinear.tsx +0 -52
  233. package/dist/src/components/progress/index.ts +0 -3
  234. package/dist/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
  235. package/dist/src/components/progress-tracker/ProgressTracker.test.tsx +0 -57
  236. package/dist/src/components/progress-tracker/ProgressTracker.tsx +0 -89
  237. package/dist/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -42
  238. package/dist/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -66
  239. package/dist/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -128
  240. package/dist/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
  241. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -73
  242. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -67
  243. package/dist/src/components/progress-tracker/__snapshots__/ProgressTracker.test.tsx.snap +0 -41
  244. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStep.test.tsx.snap +0 -141
  245. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStepPanel.test.tsx.snap +0 -25
  246. package/dist/src/components/progress-tracker/index.ts +0 -4
  247. package/dist/src/components/radio-button/RadioButton.stories.tsx +0 -28
  248. package/dist/src/components/radio-button/RadioButton.test.tsx +0 -123
  249. package/dist/src/components/radio-button/RadioButton.tsx +0 -141
  250. package/dist/src/components/radio-button/RadioGroup.stories.tsx +0 -42
  251. package/dist/src/components/radio-button/RadioGroup.test.tsx +0 -77
  252. package/dist/src/components/radio-button/RadioGroup.tsx +0 -52
  253. package/dist/src/components/radio-button/__snapshots__/RadioButton.test.tsx.snap +0 -113
  254. package/dist/src/components/radio-button/__snapshots__/RadioGroup.test.tsx.snap +0 -26
  255. package/dist/src/components/radio-button/index.ts +0 -2
  256. package/dist/src/components/select/Select.stories.tsx +0 -399
  257. package/dist/src/components/select/Select.test.tsx +0 -359
  258. package/dist/src/components/select/Select.tsx +0 -193
  259. package/dist/src/components/select/SelectMultiple.stories.tsx +0 -227
  260. package/dist/src/components/select/SelectMultiple.test.tsx +0 -405
  261. package/dist/src/components/select/SelectMultiple.tsx +0 -198
  262. package/dist/src/components/select/WithSelectContext.tsx +0 -143
  263. package/dist/src/components/select/__snapshots__/Select.test.tsx.snap +0 -43
  264. package/dist/src/components/select/__snapshots__/SelectMultiple.test.tsx.snap +0 -87
  265. package/dist/src/components/select/constants.ts +0 -53
  266. package/dist/src/components/select/index.ts +0 -2
  267. package/dist/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
  268. package/dist/src/components/side-navigation/SideNavigation.test.tsx +0 -52
  269. package/dist/src/components/side-navigation/SideNavigation.tsx +0 -54
  270. package/dist/src/components/side-navigation/SideNavigationItem.test.tsx +0 -175
  271. package/dist/src/components/side-navigation/SideNavigationItem.tsx +0 -162
  272. package/dist/src/components/side-navigation/__snapshots__/SideNavigation.test.tsx.snap +0 -7
  273. package/dist/src/components/side-navigation/__snapshots__/SideNavigationItem.test.tsx.snap +0 -30
  274. package/dist/src/components/side-navigation/index.ts +0 -2
  275. package/dist/src/components/skeleton/SkeletonCircle.stories.tsx +0 -25
  276. package/dist/src/components/skeleton/SkeletonCircle.test.tsx +0 -28
  277. package/dist/src/components/skeleton/SkeletonCircle.tsx +0 -52
  278. package/dist/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -107
  279. package/dist/src/components/skeleton/SkeletonRectangle.test.tsx +0 -28
  280. package/dist/src/components/skeleton/SkeletonRectangle.tsx +0 -78
  281. package/dist/src/components/skeleton/SkeletonTypography.stories.tsx +0 -26
  282. package/dist/src/components/skeleton/SkeletonTypography.test.tsx +0 -28
  283. package/dist/src/components/skeleton/SkeletonTypography.tsx +0 -57
  284. package/dist/src/components/skeleton/__snapshots__/SkeletonCircle.test.tsx.snap +0 -54
  285. package/dist/src/components/skeleton/__snapshots__/SkeletonRectangle.test.tsx.snap +0 -177
  286. package/dist/src/components/skeleton/__snapshots__/SkeletonTypography.test.tsx.snap +0 -174
  287. package/dist/src/components/skeleton/index.ts +0 -3
  288. package/dist/src/components/slider/Slider.stories.tsx +0 -29
  289. package/dist/src/components/slider/Slider.test.tsx +0 -31
  290. package/dist/src/components/slider/Slider.tsx +0 -299
  291. package/dist/src/components/slider/__snapshots__/Slider.test.tsx.snap +0 -122
  292. package/dist/src/components/slider/index.ts +0 -2
  293. package/dist/src/components/slideshow/Slides.tsx +0 -124
  294. package/dist/src/components/slideshow/Slideshow.stories.tsx +0 -212
  295. package/dist/src/components/slideshow/Slideshow.test.tsx +0 -39
  296. package/dist/src/components/slideshow/Slideshow.tsx +0 -170
  297. package/dist/src/components/slideshow/SlideshowControls.stories.tsx +0 -112
  298. package/dist/src/components/slideshow/SlideshowControls.tsx +0 -241
  299. package/dist/src/components/slideshow/SlideshowItem.tsx +0 -52
  300. package/dist/src/components/slideshow/SlideshowItemGroup.tsx +0 -64
  301. package/dist/src/components/slideshow/__snapshots__/Slideshow.test.tsx.snap +0 -157
  302. package/dist/src/components/slideshow/constants.ts +0 -24
  303. package/dist/src/components/slideshow/index.ts +0 -4
  304. package/dist/src/components/slideshow/useKeyNavigate.ts +0 -28
  305. package/dist/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
  306. package/dist/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
  307. package/dist/src/components/slideshow/useSwipeNavigate.ts +0 -18
  308. package/dist/src/components/switch/Switch.stories.tsx +0 -36
  309. package/dist/src/components/switch/Switch.test.tsx +0 -189
  310. package/dist/src/components/switch/Switch.tsx +0 -141
  311. package/dist/src/components/switch/__snapshots__/Switch.test.tsx.snap +0 -179
  312. package/dist/src/components/switch/index.ts +0 -1
  313. package/dist/src/components/table/Table.test.tsx +0 -28
  314. package/dist/src/components/table/Table.tsx +0 -59
  315. package/dist/src/components/table/TableBody.test.tsx +0 -22
  316. package/dist/src/components/table/TableBody.tsx +0 -44
  317. package/dist/src/components/table/TableCell.test.tsx +0 -23
  318. package/dist/src/components/table/TableCell.tsx +0 -125
  319. package/dist/src/components/table/TableHeader.test.tsx +0 -22
  320. package/dist/src/components/table/TableHeader.tsx +0 -50
  321. package/dist/src/components/table/TableRow.test.tsx +0 -22
  322. package/dist/src/components/table/TableRow.tsx +0 -68
  323. package/dist/src/components/table/__snapshots__/Table.test.tsx.snap +0 -263
  324. package/dist/src/components/table/index.ts +0 -5
  325. package/dist/src/components/tabs/Tab.test.tsx +0 -116
  326. package/dist/src/components/tabs/Tab.tsx +0 -120
  327. package/dist/src/components/tabs/TabList.test.tsx +0 -80
  328. package/dist/src/components/tabs/TabList.tsx +0 -82
  329. package/dist/src/components/tabs/TabPanel.test.tsx +0 -74
  330. package/dist/src/components/tabs/TabPanel.tsx +0 -65
  331. package/dist/src/components/tabs/TabProvider.test.tsx +0 -42
  332. package/dist/src/components/tabs/TabProvider.tsx +0 -59
  333. package/dist/src/components/tabs/Tabs.stories.tsx +0 -134
  334. package/dist/src/components/tabs/__snapshots__/Tab.test.tsx.snap +0 -62
  335. package/dist/src/components/tabs/__snapshots__/TabList.test.tsx.snap +0 -22
  336. package/dist/src/components/tabs/__snapshots__/TabPanel.test.tsx.snap +0 -25
  337. package/dist/src/components/tabs/index.ts +0 -4
  338. package/dist/src/components/tabs/state.ts +0 -116
  339. package/dist/src/components/tabs/test.mocks.ts +0 -33
  340. package/dist/src/components/text/Text.stories.jsx +0 -75
  341. package/dist/src/components/text/Text.test.tsx +0 -108
  342. package/dist/src/components/text/Text.tsx +0 -121
  343. package/dist/src/components/text/index.ts +0 -1
  344. package/dist/src/components/text-field/TextField.stories.tsx +0 -169
  345. package/dist/src/components/text-field/TextField.test.tsx +0 -171
  346. package/dist/src/components/text-field/TextField.tsx +0 -432
  347. package/dist/src/components/text-field/__snapshots__/TextField.test.tsx.snap +0 -42
  348. package/dist/src/components/text-field/index.ts +0 -1
  349. package/dist/src/components/thumbnail/Thumbnail.stories.tsx +0 -510
  350. package/dist/src/components/thumbnail/Thumbnail.test.tsx +0 -46
  351. package/dist/src/components/thumbnail/Thumbnail.tsx +0 -222
  352. package/dist/src/components/thumbnail/__snapshots__/Thumbnail.test.tsx.snap +0 -130
  353. package/dist/src/components/thumbnail/index.ts +0 -3
  354. package/dist/src/components/thumbnail/types.ts +0 -39
  355. package/dist/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
  356. package/dist/src/components/thumbnail/useFocusPointStyle.tsx +0 -111
  357. package/dist/src/components/thumbnail/useImageLoad.ts +0 -40
  358. package/dist/src/components/toolbar/Toolbar.tsx +0 -67
  359. package/dist/src/components/toolbar/index.ts +0 -1
  360. package/dist/src/components/tooltip/Tooltip.stories.tsx +0 -172
  361. package/dist/src/components/tooltip/Tooltip.test.tsx +0 -105
  362. package/dist/src/components/tooltip/Tooltip.tsx +0 -122
  363. package/dist/src/components/tooltip/__snapshots__/Tooltip.test.tsx.snap +0 -233
  364. package/dist/src/components/tooltip/index.ts +0 -1
  365. package/dist/src/components/tooltip/useInjectTooltipRef.tsx +0 -44
  366. package/dist/src/components/tooltip/useTooltipOpen.tsx +0 -113
  367. package/dist/src/components/uploader/Uploader.test.tsx +0 -87
  368. package/dist/src/components/uploader/Uploader.tsx +0 -105
  369. package/dist/src/components/uploader/__snapshots__/Uploader.test.tsx.snap +0 -14
  370. package/dist/src/components/uploader/index.ts +0 -1
  371. package/dist/src/components/user-block/UserBlock.stories.tsx +0 -76
  372. package/dist/src/components/user-block/UserBlock.test.tsx +0 -38
  373. package/dist/src/components/user-block/UserBlock.tsx +0 -179
  374. package/dist/src/components/user-block/__snapshots__/UserBlock.test.tsx.snap +0 -362
  375. package/dist/src/components/user-block/index.ts +0 -1
  376. package/dist/src/constants.ts +0 -17
  377. package/dist/src/hooks/useBooleanState.tsx +0 -13
  378. package/dist/src/hooks/useCallbackOnEscape.ts +0 -34
  379. package/dist/src/hooks/useChipGroupNavigation.tsx +0 -75
  380. package/dist/src/hooks/useClickAway.tsx +0 -47
  381. package/dist/src/hooks/useDisableBodyScroll.ts +0 -28
  382. package/dist/src/hooks/useEventCallback.tsx +0 -17
  383. package/dist/src/hooks/useFocus.tsx +0 -21
  384. package/dist/src/hooks/useFocusTrap.ts +0 -85
  385. package/dist/src/hooks/useFocusWithin.ts +0 -33
  386. package/dist/src/hooks/useInfiniteScroll.tsx +0 -60
  387. package/dist/src/hooks/useIntersectionObserver.tsx +0 -43
  388. package/dist/src/hooks/useInterval.tsx +0 -31
  389. package/dist/src/hooks/useKeyboardListNavigation.tsx +0 -204
  390. package/dist/src/hooks/useListenFocus.tsx +0 -26
  391. package/dist/src/hooks/useOnResize.ts +0 -41
  392. package/dist/src/hooks/useRovingTabIndex.tsx +0 -90
  393. package/dist/src/hooks/useSlideshowControls.ts +0 -243
  394. package/dist/src/hooks/useStopPropagation.ts +0 -21
  395. package/dist/src/hooks/useTransitionVisibility.ts +0 -54
  396. package/dist/src/index.ts +0 -58
  397. package/dist/src/stories/chromaticForceScreenSize.tsx +0 -7
  398. package/dist/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
  399. package/dist/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
  400. package/dist/src/stories/generated/Badge/Demos.stories.tsx +0 -9
  401. package/dist/src/stories/generated/Button/Demos.stories.tsx +0 -11
  402. package/dist/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
  403. package/dist/src/stories/generated/Chip/Demos.stories.tsx +0 -11
  404. package/dist/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
  405. package/dist/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
  406. package/dist/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
  407. package/dist/src/stories/generated/Divider/Demos.stories.tsx +0 -6
  408. package/dist/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
  409. package/dist/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
  410. package/dist/src/stories/generated/Flag/Demos.stories.tsx +0 -6
  411. package/dist/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
  412. package/dist/src/stories/generated/Heading/Demos.stories.tsx +0 -6
  413. package/dist/src/stories/generated/Icon/Demos.stories.tsx +0 -8
  414. package/dist/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
  415. package/dist/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
  416. package/dist/src/stories/generated/Link/Demos.stories.tsx +0 -8
  417. package/dist/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
  418. package/dist/src/stories/generated/List/Demos.stories.tsx +0 -11
  419. package/dist/src/stories/generated/Message/Demos.stories.tsx +0 -10
  420. package/dist/src/stories/generated/Mosaic/Demos.stories.tsx +0 -9
  421. package/dist/src/stories/generated/Notification/Demos.stories.tsx +0 -6
  422. package/dist/src/stories/generated/Popover/Demos.stories.tsx +0 -11
  423. package/dist/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
  424. package/dist/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
  425. package/dist/src/stories/generated/Progress/Demos.stories.tsx +0 -7
  426. package/dist/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
  427. package/dist/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
  428. package/dist/src/stories/generated/Select/Demos.stories.tsx +0 -14
  429. package/dist/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
  430. package/dist/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
  431. package/dist/src/stories/generated/Slider/Demos.stories.tsx +0 -9
  432. package/dist/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
  433. package/dist/src/stories/generated/Switch/Demos.stories.tsx +0 -6
  434. package/dist/src/stories/generated/Table/Demos.stories.tsx +0 -6
  435. package/dist/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
  436. package/dist/src/stories/generated/TextField/Demos.stories.tsx +0 -19
  437. package/dist/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
  438. package/dist/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
  439. package/dist/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
  440. package/dist/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
  441. package/dist/src/stories/generated/UserBlock/Demos.stories.tsx +0 -10
  442. package/dist/src/stories/knobs/buttonKnob.ts +0 -9
  443. package/dist/src/stories/knobs/emphasisKnob.ts +0 -8
  444. package/dist/src/stories/knobs/enumKnob.ts +0 -14
  445. package/dist/src/stories/knobs/focusKnob.ts +0 -3
  446. package/dist/src/stories/knobs/image.ts +0 -69
  447. package/dist/src/stories/knobs/lorem.ts +0 -59
  448. package/dist/src/stories/knobs/sizeKnob.ts +0 -5
  449. package/dist/src/stories/knobs/thumbnailsKnob.ts +0 -9
  450. package/dist/src/stories/utils/CustomLink.tsx +0 -7
  451. package/dist/src/stories/withResizableBox.tsx +0 -18
  452. package/dist/src/testing/utils/commonTestsSuite.ts +0 -71
  453. package/dist/src/testing/utils/commonTestsSuiteRTL.ts +0 -55
  454. package/dist/src/testing/utils/index.ts +0 -4
  455. package/dist/src/testing/utils/itShouldRenderStories.tsx +0 -103
  456. package/dist/src/testing/utils/queries.ts +0 -19
  457. package/dist/src/untypped-modules.d.ts +0 -7
  458. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -58
  459. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -65
  460. package/dist/src/utils/ClickAwayProvider/index.ts +0 -1
  461. package/dist/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
  462. package/dist/src/utils/MaterialThemeSwitcher/index.ts +0 -1
  463. package/dist/src/utils/browserDoesNotSupportHover.test.js +0 -24
  464. package/dist/src/utils/browserDoesNotSupportHover.ts +0 -2
  465. package/dist/src/utils/clamp.ts +0 -17
  466. package/dist/src/utils/className.ts +0 -44
  467. package/dist/src/utils/event.ts +0 -1
  468. package/dist/src/utils/flattenChildren.test.tsx +0 -58
  469. package/dist/src/utils/flattenChildren.ts +0 -27
  470. package/dist/src/utils/focus/constants.ts +0 -5
  471. package/dist/src/utils/focus/getFirstAndLastFocusable.test.ts +0 -134
  472. package/dist/src/utils/focus/getFirstAndLastFocusable.ts +0 -21
  473. package/dist/src/utils/focus/getFocusableElements.test.ts +0 -151
  474. package/dist/src/utils/focus/getFocusableElements.ts +0 -7
  475. package/dist/src/utils/index.ts +0 -5
  476. package/dist/src/utils/isInternetExplorer.ts +0 -15
  477. package/dist/src/utils/makeListenerTowerContext.ts +0 -32
  478. package/dist/src/utils/mergeRefs.ts +0 -22
  479. package/dist/src/utils/partitionMulti.ts +0 -28
  480. package/dist/src/utils/renderLink.tsx +0 -17
  481. package/dist/src/utils/type.ts +0 -113
  482. package/dist/src/utils/userHasReducedMotion.ts +0 -7
  483. package/dist/src/utils/utils.test.ts +0 -48
  484. package/jest/__mocks__/@storybook/addon-actions.js +0 -3
  485. package/jest/__mocks__/@storybook/addon-knobs.js +0 -6
  486. package/jest/__mocks__/emptyFileMockTransformer.js +0 -8
  487. package/jest/__mocks__/emptyModuleMock.js +0 -1
  488. package/jest/configure.js +0 -6
  489. package/jest/index.js +0 -36
  490. package/jest/transform.js +0 -6
  491. package/rollup.config.js +0 -98
  492. package/storybook/build +0 -4
  493. package/storybook/generate-demo-stories.js +0 -59
  494. package/storybook/main.js +0 -67
  495. package/storybook/package.json +0 -13
  496. package/storybook/preview.js +0 -11
  497. package/storybook/start +0 -4
  498. package/storybook/story-block/StoryBlock.tsx +0 -49
  499. package/storybook/story-block/decorator.jsx +0 -7
  500. package/storybook/story-block/index.scss +0 -27
  501. package/storybook/yarn.lock +0 -13192
  502. package/tsconfig.json +0 -3
@@ -1,44 +0,0 @@
1
- import { mergeRefs } from '@lumx/react/utils/mergeRefs';
2
- import get from 'lodash/get';
3
- import React, { cloneElement, ReactNode, useMemo } from 'react';
4
-
5
- /**
6
- * Add ref and ARIA attribute(s) in tooltip children or wrapped children.
7
- * Button, IconButton, Icon and React HTML elements don't need to be wrapped but any other kind of children (array, fragment, custom components)
8
- * will be wrapped in a <span>.
9
- *
10
- * @param children Original tooltip anchor.
11
- * @param setAnchorElement Set tooltip anchor element.
12
- * @param isOpen Whether the tooltip is open or not.
13
- * @param id Tooltip id.
14
- * @return tooltip anchor.
15
- */
16
- export const useInjectTooltipRef = (
17
- children: ReactNode,
18
- setAnchorElement: (e: HTMLDivElement) => void,
19
- isOpen: boolean,
20
- id: string,
21
- ): ReactNode => {
22
- return useMemo(() => {
23
- const ariaProps = { 'aria-describedby': isOpen ? id : undefined };
24
- if (
25
- children &&
26
- get(children, '$$typeof') &&
27
- get(children, 'props.disabled') !== true &&
28
- get(children, 'props.isDisabled') !== true
29
- ) {
30
- const element = children as any;
31
-
32
- return cloneElement(element, {
33
- ...element.props,
34
- ...ariaProps,
35
- ref: mergeRefs(element.ref, setAnchorElement),
36
- });
37
- }
38
- return (
39
- <div className="lumx-tooltip-anchor-wrapper" ref={setAnchorElement} {...ariaProps}>
40
- {children}
41
- </div>
42
- );
43
- }, [isOpen, id, children, setAnchorElement]);
44
- };
@@ -1,113 +0,0 @@
1
- import { onEscapePressed } from '@lumx/react/utils/event';
2
- import { useEffect, useState } from 'react';
3
- import { browserDoesNotSupportHover } from '@lumx/react/utils/browserDoesNotSupportHover';
4
- import { TOOLTIP_HOVER_DELAY, TOOLTIP_LONG_PRESS_DELAY } from '@lumx/react/constants';
5
-
6
- /**
7
- * Hook controlling tooltip visibility using mouse hover the anchor and delay.
8
- *
9
- * @param delay Delay in millisecond to display the tooltip.
10
- * @param anchorElement Tooltip anchor element.
11
- * @return whether or not to show the tooltip.
12
- */
13
- export function useTooltipOpen(delay: number | undefined, anchorElement: HTMLElement | null): boolean {
14
- const [isOpen, setIsOpen] = useState(false);
15
-
16
- useEffect(() => {
17
- if (!anchorElement) {
18
- return undefined;
19
- }
20
- let timer: number | undefined;
21
- let openStartTime: number | undefined;
22
- let shouldOpen: boolean | undefined;
23
-
24
- // Run timer to defer updating the isOpen state.
25
- const deferUpdate = (duration: number) => {
26
- if (timer) clearTimeout(timer);
27
- timer = setTimeout(() => {
28
- setIsOpen(!!shouldOpen);
29
- }, duration) as any;
30
- };
31
-
32
- const hoverNotSupported = browserDoesNotSupportHover();
33
- const hasTouch = 'ontouchstart' in window;
34
-
35
- // Adapt open/close delay
36
- const openDelay = delay || (hoverNotSupported ? TOOLTIP_LONG_PRESS_DELAY.open : TOOLTIP_HOVER_DELAY.open);
37
- const closeDelay = hoverNotSupported ? TOOLTIP_LONG_PRESS_DELAY.close : TOOLTIP_HOVER_DELAY.close;
38
-
39
- // Open (or/and cancel closing) of tooltip.
40
- const open = () => {
41
- if (shouldOpen && !timer) return;
42
- shouldOpen = true;
43
- openStartTime = Date.now();
44
- deferUpdate(openDelay);
45
- };
46
-
47
- // Close or cancel opening of tooltip
48
- const close = (overrideDelay = closeDelay) => {
49
- if (!shouldOpen && !timer) return;
50
- shouldOpen = false;
51
- deferUpdate(overrideDelay);
52
- };
53
- const closeImmediately = () => close(0);
54
-
55
- /**
56
- * Handle touchend event
57
- * If `touchend` comes before the open delay => cancel tooltip (close immediate).
58
- * Else if `touchend` comes after the open delay => tooltip takes priority, the anchor's default touch end event is prevented.
59
- */
60
- const touchEnd = (evt: Event) => {
61
- if (!openStartTime) return;
62
- if (Date.now() - openStartTime >= openDelay) {
63
- // Tooltip take priority, event prevented.
64
- evt.stopPropagation();
65
- evt.preventDefault();
66
- anchorElement.focus();
67
- // Close with delay.
68
- close();
69
- } else {
70
- // Close immediately.
71
- closeImmediately();
72
- }
73
- };
74
-
75
- // Adapt event to browsers with or without `hover` support.
76
- const events: Array<[Node, Event['type'], any]> = hoverNotSupported
77
- ? [
78
- [anchorElement, hasTouch ? 'touchstart' : 'mousedown', open],
79
- [anchorElement, hasTouch ? 'touchend' : 'mouseup', touchEnd],
80
- ]
81
- : [
82
- [anchorElement, 'mouseenter', open],
83
- [anchorElement, 'mouseleave', close],
84
- [anchorElement, 'mouseup', closeImmediately],
85
- ];
86
-
87
- // Events always applied no matter the browser:.
88
- events.push(
89
- // Open on focus.
90
- [anchorElement, 'focusin', open],
91
- // Close on lost focus.
92
- [anchorElement, 'focusout', closeImmediately],
93
- // Close on ESC keydown
94
- [anchorElement, 'keydown', onEscapePressed(closeImmediately)],
95
- );
96
-
97
- // Attach events
98
- for (const [node, eventType, eventHandler] of events) {
99
- node.addEventListener(eventType, eventHandler);
100
- }
101
- return () => {
102
- // Clear pending timers.
103
- if (timer) clearTimeout(timer);
104
-
105
- // Detach events.
106
- for (const [node, eventType, eventHandler] of events) {
107
- node.removeEventListener(eventType, eventHandler);
108
- }
109
- };
110
- }, [anchorElement, delay]);
111
-
112
- return isOpen;
113
- }
@@ -1,87 +0,0 @@
1
- import React, { ReactElement } from 'react';
2
-
3
- import { mount, shallow } from 'enzyme';
4
- import 'jest-enzyme';
5
-
6
- import { commonTestsSuite, Wrapper } from '@lumx/react/testing/utils';
7
- import { getBasicClass } from '@lumx/react/utils/className';
8
-
9
- import { Uploader, UploaderProps } from './Uploader';
10
-
11
- const DEFAULT_PROPS = Uploader.defaultProps as any;
12
- const CLASSNAME = Uploader.className as string;
13
-
14
- type SetupProps = Partial<UploaderProps>;
15
-
16
- /**
17
- * Mounts the component and returns common DOM elements / data needed in multiple tests further down.
18
- */
19
- const setup = (propsOverride: SetupProps = {}, shallowRendering = true) => {
20
- const props: any = { ...propsOverride };
21
- const renderer: (el: ReactElement) => Wrapper = shallowRendering ? shallow : mount;
22
- const wrapper: Wrapper = renderer(<Uploader {...props} />);
23
-
24
- return { props, wrapper };
25
- };
26
-
27
- describe(`<${Uploader.displayName}>`, () => {
28
- // 1. Test render via snapshot (default states of component).
29
- describe('Snapshots and structure', () => {
30
- // Here is an example of a basic rendering check, with snapshot.
31
-
32
- it('should render correctly', () => {
33
- const { wrapper } = setup();
34
- expect(wrapper).toMatchSnapshot();
35
-
36
- expect(wrapper).toExist();
37
- expect(wrapper).toHaveClassName(CLASSNAME);
38
- });
39
- });
40
-
41
- // 2. Test defaultProps value and important props custom values.
42
- describe('Props', () => {
43
- // Here are some examples of basic props check.
44
-
45
- it('should use default props', () => {
46
- const { wrapper } = setup();
47
-
48
- Object.keys(DEFAULT_PROPS).forEach((prop: string) => {
49
- expect(wrapper).toHaveClassName(
50
- getBasicClass({ prefix: CLASSNAME, type: prop, value: DEFAULT_PROPS[prop] }),
51
- );
52
- });
53
- });
54
- });
55
-
56
- // 3. Test events.
57
- describe('Events', () => {
58
- // Here is an example how to check a `onClick` event.
59
-
60
- const onClick: jest.Mock = jest.fn();
61
-
62
- beforeEach(() => {
63
- onClick.mockClear();
64
- });
65
-
66
- it('should trigger `onClick` when clicked', () => {
67
- const { wrapper } = setup({ onClick }, false);
68
-
69
- wrapper.simulate('click');
70
-
71
- expect(onClick).toHaveBeenCalled();
72
- });
73
- });
74
-
75
- // 4. Test conditions (i.e. things that display or not in the UI based on props).
76
- describe('Conditions', () => {
77
- // Nothing to do here.
78
- });
79
-
80
- // 5. Test state.
81
- describe('State', () => {
82
- // Nothing to do here.
83
- });
84
-
85
- // Common tests suite.
86
- commonTestsSuite(setup, { className: 'wrapper', prop: 'wrapper' }, { className: CLASSNAME });
87
- });
@@ -1,105 +0,0 @@
1
- import React, { forwardRef, MouseEventHandler } from 'react';
2
-
3
- import classNames from 'classnames';
4
-
5
- import { AspectRatio, Icon, Size, Theme } from '@lumx/react';
6
- import { Comp, GenericProps, HasTheme, ValueOf } from '@lumx/react/utils/type';
7
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
8
-
9
- /**
10
- * Uploader variants.
11
- */
12
- export const UploaderVariant = {
13
- square: 'square',
14
- rounded: 'rounded',
15
- circle: 'circle',
16
- } as const;
17
- export type UploaderVariant = ValueOf<typeof UploaderVariant>;
18
-
19
- /**
20
- * Uploader sizes.
21
- */
22
- export type UploaderSize = Extract<Size, 'xl' | 'xxl'>;
23
-
24
- /**
25
- * Defines the props of the component.
26
- */
27
- export interface UploaderProps extends GenericProps, HasTheme {
28
- /** Image aspect ratio. */
29
- aspectRatio?: AspectRatio;
30
- /** Icon (SVG path). */
31
- icon?: string;
32
- /** Label text. */
33
- label?: string;
34
- /** Size variant. */
35
- size?: UploaderSize;
36
- /** Variant. */
37
- variant?: UploaderVariant;
38
- /** On click callback. */
39
- onClick?: MouseEventHandler<HTMLDivElement>;
40
- }
41
-
42
- /**
43
- * Component display name.
44
- */
45
- const COMPONENT_NAME = 'Uploader';
46
-
47
- /**
48
- * Component default class name and class prefix.
49
- */
50
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
51
-
52
- /**
53
- * Component default props.
54
- */
55
- const DEFAULT_PROPS: Partial<UploaderProps> = {
56
- aspectRatio: AspectRatio.horizontal,
57
- size: Size.xl,
58
- theme: Theme.light,
59
- variant: UploaderVariant.square,
60
- };
61
-
62
- /**
63
- * Uploader component.
64
- *
65
- * @param props Component props.
66
- * @param ref Component ref.
67
- * @return React element.
68
- */
69
- export const Uploader: Comp<UploaderProps, HTMLDivElement> = forwardRef((props, ref) => {
70
- const { aspectRatio, className, label, icon, size, theme, variant, ...forwardedProps } = props;
71
- // Adjust to square aspect ratio when using circle variants.
72
- const adjustedAspectRatio = variant === UploaderVariant.circle ? AspectRatio.square : aspectRatio;
73
-
74
- return (
75
- <div
76
- ref={ref}
77
- {...forwardedProps}
78
- className={classNames(
79
- className,
80
- handleBasicClasses({
81
- aspectRatio: adjustedAspectRatio,
82
- prefix: CLASSNAME,
83
- size,
84
- theme,
85
- variant,
86
- }),
87
- )}
88
- >
89
- <div className={`${CLASSNAME}__background`} />
90
-
91
- <div className={`${CLASSNAME}__wrapper`}>
92
- {icon && (
93
- <div className={`${CLASSNAME}__icon`}>
94
- <Icon icon={icon} size={Size.s} />
95
- </div>
96
- )}
97
-
98
- {label && <span className={`${CLASSNAME}__label`}>{label}</span>}
99
- </div>
100
- </div>
101
- );
102
- });
103
- Uploader.displayName = COMPONENT_NAME;
104
- Uploader.className = CLASSNAME;
105
- Uploader.defaultProps = DEFAULT_PROPS;
@@ -1,14 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`<Uploader> Snapshots and structure should render correctly 1`] = `
4
- <div
5
- className="lumx-uploader lumx-uploader--aspect-ratio-horizontal lumx-uploader--size-xl lumx-uploader--theme-light lumx-uploader--variant-square"
6
- >
7
- <div
8
- className="lumx-uploader__background"
9
- />
10
- <div
11
- className="lumx-uploader__wrapper"
12
- />
13
- </div>
14
- `;
@@ -1 +0,0 @@
1
- export * from './Uploader';
@@ -1,76 +0,0 @@
1
- import React from 'react';
2
-
3
- import { mdiStar } from '@lumx/icons';
4
- import { Badge, ColorPalette, Icon, Size } from '@lumx/react';
5
- import { avatarImageKnob } from '@lumx/react/stories/knobs/image';
6
- import { CustomLink } from '@lumx/react/stories/utils/CustomLink';
7
-
8
- import { UserBlock } from './UserBlock';
9
-
10
- export default { title: 'LumX components/user-block/UserBlock' };
11
-
12
- const logAction = (action: string) => () => console.log(action);
13
- const sizes = [Size.s, Size.m, Size.l];
14
-
15
- export const Default = ({ theme }: any) => (
16
- <UserBlock
17
- theme={theme}
18
- name="Emmitt O. Lum"
19
- fields={['Creative developer', 'Denpasar']}
20
- avatarProps={{ image: avatarImageKnob() }}
21
- onMouseEnter={logAction('Mouse entered')}
22
- onMouseLeave={logAction('Mouse left')}
23
- />
24
- );
25
-
26
- export const Sizes = ({ theme }: any) =>
27
- sizes.map((size) => (
28
- <UserBlock
29
- key={size}
30
- theme={theme}
31
- name="Emmitt O. Lum"
32
- fields={['Creative developer', 'Denpasar']}
33
- avatarProps={{ image: avatarImageKnob() }}
34
- size={size}
35
- onMouseEnter={logAction('Mouse entered')}
36
- onMouseLeave={logAction('Mouse left')}
37
- />
38
- ));
39
-
40
- export const Clickable = ({ theme }: any) => {
41
- const baseProps = {
42
- theme,
43
- name: 'Emmitt O. Lum',
44
- nameProps: { 'aria-label': 'Emmitt O. Lum - open user profile' },
45
- fields: ['Creative developer', 'Denpasar'],
46
- avatarProps: { image: avatarImageKnob() },
47
- } as any;
48
- return (
49
- <>
50
- <p>As a button</p>
51
- <UserBlock {...baseProps} onClick={logAction('UserBlock clicked')} />
52
-
53
- <p>As a link</p>
54
- <UserBlock {...baseProps} linkProps={{ href: 'https://example.com' }} />
55
-
56
- <p>As a custom link component</p>
57
- <UserBlock {...baseProps} linkAs={CustomLink} />
58
- </>
59
- );
60
- };
61
-
62
- export const WithBadge = ({ theme }: any) => (
63
- <UserBlock
64
- theme={theme}
65
- name="Emmitt O. Lum"
66
- fields={['Creative developer', 'Denpasar']}
67
- avatarProps={{
68
- image: avatarImageKnob(),
69
- badge: (
70
- <Badge color={ColorPalette.blue}>
71
- <Icon icon={mdiStar} />
72
- </Badge>
73
- ),
74
- }}
75
- />
76
- );
@@ -1,38 +0,0 @@
1
- import React, { ReactElement } from 'react';
2
-
3
- import { mount, shallow } from 'enzyme';
4
- import 'jest-enzyme';
5
-
6
- import { commonTestsSuite, itShouldRenderStories, Wrapper } from '@lumx/react/testing/utils';
7
-
8
- import { UserBlock, UserBlockProps } from './UserBlock';
9
- import * as stories from './UserBlock.stories';
10
-
11
- const CLASSNAME = UserBlock.className as string;
12
-
13
- /**
14
- * Mounts the component and returns common DOM elements / data needed in multiple tests further down.
15
- */
16
- const setup = ({ ...propsOverride }: Partial<UserBlockProps> = {}, shallowRendering = true) => {
17
- const props: UserBlockProps = { ...propsOverride };
18
- const renderer: (el: ReactElement) => Wrapper = shallowRendering ? shallow : mount;
19
- const wrapper: Wrapper = renderer(<UserBlock {...props} />);
20
-
21
- return { props, wrapper };
22
- };
23
-
24
- describe(`<${UserBlock.displayName}>`, () => {
25
- // 1. Test render via snapshot.
26
- describe('Snapshots and structure', () => {
27
- itShouldRenderStories(stories, UserBlock);
28
-
29
- it('should forward name props', () => {
30
- const { wrapper } = setup({ name: 'John Doe', nameProps: { 'data-custom-attribute': true } });
31
-
32
- expect(wrapper.find('.lumx-user-block__name[data-custom-attribute]')).toHaveLength(1);
33
- });
34
- });
35
-
36
- // Common tests suite.
37
- commonTestsSuite(setup, { className: 'wrapper', prop: 'wrapper' }, { className: CLASSNAME });
38
- });
@@ -1,179 +0,0 @@
1
- import React, { forwardRef, ReactNode } from 'react';
2
- import isEmpty from 'lodash/isEmpty';
3
- import classNames from 'classnames';
4
- import set from 'lodash/set';
5
-
6
- import { Avatar, ColorPalette, Link, Orientation, Size, Theme } from '@lumx/react';
7
- import { Comp, GenericProps, HasTheme } from '@lumx/react/utils/type';
8
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
9
-
10
- import { AvatarProps } from '../avatar/Avatar';
11
-
12
- /**
13
- * User block sizes.
14
- */
15
- export type UserBlockSize = Extract<Size, 's' | 'm' | 'l'>;
16
-
17
- /**
18
- * Defines the props of the component.
19
- */
20
- export interface UserBlockProps extends GenericProps, HasTheme {
21
- /** Props to pass to the avatar. */
22
- avatarProps?: Omit<AvatarProps, 'alt'>;
23
- /** Additional fields used to describe the user. */
24
- fields?: string[];
25
- /** Props to pass to the link wrapping the avatar thumbnail. */
26
- linkProps?: React.DetailedHTMLProps<React.AnchorHTMLAttributes<HTMLAnchorElement>, HTMLAnchorElement>;
27
- /** Custom react component for the link (can be used to inject react router Link). */
28
- linkAs?: 'a' | any;
29
- /** Multiple action toolbar content. */
30
- multipleActions?: ReactNode;
31
- /** User name. */
32
- name?: string;
33
- /** Props to pass to the name block. */
34
- nameProps?: GenericProps;
35
- /** Orientation. */
36
- orientation?: Orientation;
37
- /** Simple action toolbar content. */
38
- simpleAction?: ReactNode;
39
- /** Size variant. */
40
- size?: UserBlockSize;
41
- /** On click callback. */
42
- onClick?(): void;
43
- /** On mouse enter callback. */
44
- onMouseEnter?(): void;
45
- /** On mouse leave callback. */
46
- onMouseLeave?(): void;
47
- }
48
-
49
- /**
50
- * Component display name.
51
- */
52
- const COMPONENT_NAME = 'UserBlock';
53
-
54
- /**
55
- * Component default class name and class prefix.
56
- */
57
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
58
-
59
- /**
60
- * Component default props.
61
- */
62
- const DEFAULT_PROPS: Partial<UserBlockProps> = {
63
- orientation: Orientation.horizontal,
64
- size: Size.m,
65
- theme: Theme.light,
66
- };
67
-
68
- /**
69
- * UserBlock component.
70
- *
71
- * @param props Component props.
72
- * @param ref Component ref.
73
- * @return React element.
74
- */
75
- export const UserBlock: Comp<UserBlockProps, HTMLDivElement> = forwardRef((props, ref) => {
76
- const {
77
- avatarProps,
78
- className,
79
- fields,
80
- linkProps,
81
- linkAs,
82
- multipleActions,
83
- name,
84
- nameProps,
85
- onClick,
86
- onMouseEnter,
87
- onMouseLeave,
88
- orientation,
89
- simpleAction,
90
- size,
91
- theme,
92
- ...forwardedProps
93
- } = props;
94
- let componentSize = size;
95
-
96
- // Special case - When using vertical orientation force the size to be Sizes.l.
97
- if (orientation === Orientation.vertical) {
98
- componentSize = Size.l;
99
- }
100
-
101
- const shouldDisplayActions: boolean = orientation === Orientation.vertical;
102
-
103
- const isLink = Boolean(linkProps?.href || linkAs);
104
- const isClickable = !!onClick || isLink;
105
-
106
- const nameBlock: ReactNode = React.useMemo(() => {
107
- if (isEmpty(name)) {
108
- return null;
109
- }
110
- let NameComponent: any = 'span';
111
- const nProps: any = {
112
- ...nameProps,
113
- className: classNames(`${CLASSNAME}__name`, linkProps?.className, nameProps?.className),
114
- };
115
- if (isClickable) {
116
- NameComponent = Link;
117
- Object.assign(nProps, {
118
- ...linkProps,
119
- onClick,
120
- linkAs,
121
- color: ColorPalette.dark,
122
- });
123
- }
124
- // Disable avatar focus since the name block is the same link / same button.
125
- if (avatarProps) {
126
- set(avatarProps, ['thumbnailProps', 'tabIndex'], -1);
127
- }
128
- return <NameComponent {...nProps}>{name}</NameComponent>;
129
- }, [avatarProps, isClickable, linkAs, linkProps, name, nameProps, onClick]);
130
-
131
- const fieldsBlock: ReactNode = fields && componentSize !== Size.s && (
132
- <div className={`${CLASSNAME}__fields`}>
133
- {fields.map((field: string, idx: number) => (
134
- <span key={idx} className={`${CLASSNAME}__field`}>
135
- {field}
136
- </span>
137
- ))}
138
- </div>
139
- );
140
-
141
- return (
142
- <div
143
- ref={ref}
144
- {...forwardedProps}
145
- className={classNames(
146
- className,
147
- handleBasicClasses({ prefix: CLASSNAME, orientation, size: componentSize, theme, isClickable }),
148
- )}
149
- onMouseLeave={onMouseLeave}
150
- onMouseEnter={onMouseEnter}
151
- >
152
- {avatarProps && (
153
- <Avatar
154
- linkAs={linkAs}
155
- linkProps={linkProps}
156
- alt=""
157
- {...(avatarProps as any)}
158
- className={classNames(`${CLASSNAME}__avatar`, avatarProps.className)}
159
- size={componentSize}
160
- onClick={onClick}
161
- theme={theme}
162
- />
163
- )}
164
- {(fields || name) && (
165
- <div className={`${CLASSNAME}__wrapper`}>
166
- {nameBlock}
167
- {fieldsBlock}
168
- </div>
169
- )}
170
- {shouldDisplayActions && simpleAction && <div className={`${CLASSNAME}__action`}>{simpleAction}</div>}
171
- {shouldDisplayActions && multipleActions && (
172
- <div className={`${CLASSNAME}__actions`}>{multipleActions}</div>
173
- )}
174
- </div>
175
- );
176
- });
177
- UserBlock.displayName = COMPONENT_NAME;
178
- UserBlock.className = CLASSNAME;
179
- UserBlock.defaultProps = DEFAULT_PROPS;