@lumx/react 3.1.1 → 3.1.3-alpha.0

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