@lumx/react 3.1.0 → 3.1.2

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