@lumx/react 3.0.7-alpha.2 → 3.0.7-alpha.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (502) hide show
  1. package/{dist/CONTRIBUTING.md → CONTRIBUTING.md} +0 -0
  2. package/{dist/LICENSE.md → LICENSE.md} +0 -0
  3. package/{dist/_internal → _internal}/ClickAwayProvider.js +0 -0
  4. package/{dist/_internal → _internal}/ClickAwayProvider.js.map +0 -0
  5. package/{dist/_internal → _internal}/types.d.ts +1 -1
  6. package/{dist/index.d.ts → index.d.ts} +7 -7
  7. package/{dist/index.js → index.js} +0 -0
  8. package/{dist/index.js.map → index.js.map} +1 -1
  9. package/package.json +3 -3
  10. package/src/components/badge/Badge.tsx +2 -2
  11. package/src/components/button/ButtonRoot.tsx +2 -2
  12. package/src/components/chip/Chip.tsx +2 -2
  13. package/src/components/icon/Icon.tsx +2 -2
  14. package/src/components/link/Link.tsx +2 -2
  15. package/{dist/utils → utils}/index.d.ts +0 -0
  16. package/{dist/utils → utils}/index.js +0 -0
  17. package/{dist/utils → utils}/index.js.map +0 -0
  18. package/dist/README.md +0 -38
  19. package/dist/package.json +0 -117
  20. package/dist/src/components/alert-dialog/AlertDialog.stories.tsx +0 -196
  21. package/dist/src/components/alert-dialog/AlertDialog.test.tsx +0 -43
  22. package/dist/src/components/alert-dialog/AlertDialog.tsx +0 -185
  23. package/dist/src/components/alert-dialog/__snapshots__/AlertDialog.test.tsx.snap +0 -551
  24. package/dist/src/components/alert-dialog/index.ts +0 -1
  25. package/dist/src/components/autocomplete/Autocomplete.stories.tsx +0 -70
  26. package/dist/src/components/autocomplete/Autocomplete.test.tsx +0 -181
  27. package/dist/src/components/autocomplete/Autocomplete.tsx +0 -292
  28. package/dist/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -170
  29. package/dist/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -94
  30. package/dist/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
  31. package/dist/src/components/autocomplete/__mockData__/index.ts +0 -34
  32. package/dist/src/components/autocomplete/__snapshots__/Autocomplete.test.tsx.snap +0 -213
  33. package/dist/src/components/autocomplete/__snapshots__/AutocompleteMultiple.test.tsx.snap +0 -88
  34. package/dist/src/components/autocomplete/index.ts +0 -2
  35. package/dist/src/components/avatar/Avatar.stories.tsx +0 -92
  36. package/dist/src/components/avatar/Avatar.test.tsx +0 -39
  37. package/dist/src/components/avatar/Avatar.tsx +0 -112
  38. package/dist/src/components/avatar/__snapshots__/Avatar.test.tsx.snap +0 -681
  39. package/dist/src/components/avatar/index.ts +0 -1
  40. package/dist/src/components/badge/Badge.stories.tsx +0 -45
  41. package/dist/src/components/badge/Badge.test.tsx +0 -91
  42. package/dist/src/components/badge/Badge.tsx +0 -55
  43. package/dist/src/components/badge/__snapshots__/Badge.test.tsx.snap +0 -11
  44. package/dist/src/components/badge/index.ts +0 -1
  45. package/dist/src/components/button/Button.stories.tsx +0 -156
  46. package/dist/src/components/button/Button.test.tsx +0 -152
  47. package/dist/src/components/button/Button.tsx +0 -81
  48. package/dist/src/components/button/ButtonGroup.test.tsx +0 -66
  49. package/dist/src/components/button/ButtonGroup.tsx +0 -46
  50. package/dist/src/components/button/ButtonRoot.test.tsx +0 -203
  51. package/dist/src/components/button/ButtonRoot.tsx +0 -190
  52. package/dist/src/components/button/IconButton.test.tsx +0 -103
  53. package/dist/src/components/button/IconButton.tsx +0 -80
  54. package/dist/src/components/button/__snapshots__/Button.test.tsx.snap +0 -96
  55. package/dist/src/components/button/__snapshots__/ButtonGroup.test.tsx.snap +0 -22
  56. package/dist/src/components/button/__snapshots__/ButtonRoot.test.tsx.snap +0 -160
  57. package/dist/src/components/button/__snapshots__/IconButton.test.tsx.snap +0 -83
  58. package/dist/src/components/button/index.ts +0 -4
  59. package/dist/src/components/checkbox/Checkbox.stories.tsx +0 -37
  60. package/dist/src/components/checkbox/Checkbox.test.tsx +0 -114
  61. package/dist/src/components/checkbox/Checkbox.tsx +0 -145
  62. package/dist/src/components/checkbox/__snapshots__/Checkbox.test.tsx.snap +0 -141
  63. package/dist/src/components/checkbox/index.ts +0 -1
  64. package/dist/src/components/chip/Chip.stories.tsx +0 -21
  65. package/dist/src/components/chip/Chip.test.tsx +0 -199
  66. package/dist/src/components/chip/Chip.tsx +0 -154
  67. package/dist/src/components/chip/ChipGroup.test.tsx +0 -29
  68. package/dist/src/components/chip/ChipGroup.tsx +0 -62
  69. package/dist/src/components/chip/__snapshots__/Chip.test.tsx.snap +0 -12
  70. package/dist/src/components/chip/__snapshots__/ChipGroup.test.tsx.snap +0 -29
  71. package/dist/src/components/chip/index.ts +0 -2
  72. package/dist/src/components/comment-block/CommentBlock.stories.tsx +0 -30
  73. package/dist/src/components/comment-block/CommentBlock.test.tsx +0 -28
  74. package/dist/src/components/comment-block/CommentBlock.tsx +0 -174
  75. package/dist/src/components/comment-block/__snapshots__/CommentBlock.test.tsx.snap +0 -92
  76. package/dist/src/components/comment-block/index.ts +0 -1
  77. package/dist/src/components/date-picker/DatePicker.test.tsx +0 -41
  78. package/dist/src/components/date-picker/DatePicker.tsx +0 -56
  79. package/dist/src/components/date-picker/DatePickerControlled.test.tsx +0 -44
  80. package/dist/src/components/date-picker/DatePickerControlled.tsx +0 -128
  81. package/dist/src/components/date-picker/DatePickerField.stories.tsx +0 -93
  82. package/dist/src/components/date-picker/DatePickerField.test.tsx +0 -47
  83. package/dist/src/components/date-picker/DatePickerField.tsx +0 -141
  84. package/dist/src/components/date-picker/__snapshots__/DatePicker.test.tsx.snap +0 -22
  85. package/dist/src/components/date-picker/__snapshots__/DatePickerControlled.test.tsx.snap +0 -597
  86. package/dist/src/components/date-picker/__snapshots__/DatePickerField.test.tsx.snap +0 -43
  87. package/dist/src/components/date-picker/constants.ts +0 -11
  88. package/dist/src/components/date-picker/index.ts +0 -4
  89. package/dist/src/components/date-picker/types.ts +0 -28
  90. package/dist/src/components/dialog/Dialog.stories.tsx +0 -426
  91. package/dist/src/components/dialog/Dialog.test.tsx +0 -93
  92. package/dist/src/components/dialog/Dialog.tsx +0 -263
  93. package/dist/src/components/dialog/__snapshots__/Dialog.test.tsx.snap +0 -960
  94. package/dist/src/components/dialog/index.ts +0 -1
  95. package/dist/src/components/divider/Divider.test.tsx +0 -93
  96. package/dist/src/components/divider/Divider.tsx +0 -51
  97. package/dist/src/components/divider/__snapshots__/Divider.test.tsx.snap +0 -9
  98. package/dist/src/components/divider/index.ts +0 -1
  99. package/dist/src/components/drag-handle/DragHandle.tsx +0 -50
  100. package/dist/src/components/drag-handle/index.ts +0 -1
  101. package/dist/src/components/dropdown/Dropdown.stories.tsx +0 -216
  102. package/dist/src/components/dropdown/Dropdown.test.tsx +0 -97
  103. package/dist/src/components/dropdown/Dropdown.tsx +0 -184
  104. package/dist/src/components/dropdown/__snapshots__/Dropdown.test.tsx.snap +0 -35
  105. package/dist/src/components/dropdown/index.ts +0 -1
  106. package/dist/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -116
  107. package/dist/src/components/expansion-panel/ExpansionPanel.tsx +0 -170
  108. package/dist/src/components/expansion-panel/index.ts +0 -1
  109. package/dist/src/components/flag/Flag.stories.tsx +0 -23
  110. package/dist/src/components/flag/Flag.test.tsx +0 -86
  111. package/dist/src/components/flag/Flag.tsx +0 -47
  112. package/dist/src/components/flag/__snapshots__/Flag.test.tsx.snap +0 -133
  113. package/dist/src/components/flag/index.ts +0 -1
  114. package/dist/src/components/flex-box/FlexBox.stories.tsx +0 -245
  115. package/dist/src/components/flex-box/FlexBox.test.tsx +0 -65
  116. package/dist/src/components/flex-box/FlexBox.tsx +0 -98
  117. package/dist/src/components/flex-box/__snapshots__/FlexBox.test.tsx.snap +0 -492
  118. package/dist/src/components/flex-box/index.ts +0 -1
  119. package/dist/src/components/generic-block/GenericBlock.stories.jsx +0 -128
  120. package/dist/src/components/generic-block/GenericBlock.test.tsx +0 -152
  121. package/dist/src/components/generic-block/GenericBlock.tsx +0 -222
  122. package/dist/src/components/generic-block/constants.ts +0 -9
  123. package/dist/src/components/generic-block/index.ts +0 -2
  124. package/dist/src/components/grid/Grid.tsx +0 -73
  125. package/dist/src/components/grid/GridItem.tsx +0 -54
  126. package/dist/src/components/grid/index.ts +0 -2
  127. package/dist/src/components/grid-column/GridColumn.stories.jsx +0 -56
  128. package/dist/src/components/grid-column/GridColumn.test.jsx +0 -58
  129. package/dist/src/components/grid-column/GridColumn.tsx +0 -90
  130. package/dist/src/components/grid-column/index.ts +0 -1
  131. package/dist/src/components/heading/Heading.stories.tsx +0 -108
  132. package/dist/src/components/heading/Heading.test.tsx +0 -82
  133. package/dist/src/components/heading/Heading.tsx +0 -63
  134. package/dist/src/components/heading/HeadingLevelProvider.tsx +0 -30
  135. package/dist/src/components/heading/constants.ts +0 -16
  136. package/dist/src/components/heading/context.tsx +0 -13
  137. package/dist/src/components/heading/index.ts +0 -3
  138. package/dist/src/components/heading/useHeadingLevel.tsx +0 -8
  139. package/dist/src/components/icon/Icon.stories.tsx +0 -76
  140. package/dist/src/components/icon/Icon.test.tsx +0 -102
  141. package/dist/src/components/icon/Icon.tsx +0 -121
  142. package/dist/src/components/icon/__snapshots__/Icon.test.tsx.snap +0 -49
  143. package/dist/src/components/icon/index.ts +0 -1
  144. package/dist/src/components/image-block/ImageBlock.stories.tsx +0 -52
  145. package/dist/src/components/image-block/ImageBlock.test.tsx +0 -28
  146. package/dist/src/components/image-block/ImageBlock.tsx +0 -151
  147. package/dist/src/components/image-block/__snapshots__/ImageBlock.test.tsx.snap +0 -64
  148. package/dist/src/components/image-block/index.ts +0 -1
  149. package/dist/src/components/index.ts +0 -176
  150. package/dist/src/components/inline-list/InlineList.stories.tsx +0 -40
  151. package/dist/src/components/inline-list/InlineList.test.tsx +0 -41
  152. package/dist/src/components/inline-list/InlineList.tsx +0 -82
  153. package/dist/src/components/inline-list/index.ts +0 -1
  154. package/dist/src/components/input-helper/InputHelper.stories.tsx +0 -29
  155. package/dist/src/components/input-helper/InputHelper.test.tsx +0 -107
  156. package/dist/src/components/input-helper/InputHelper.tsx +0 -61
  157. package/dist/src/components/input-helper/__snapshots__/InputHelper.test.tsx.snap +0 -9
  158. package/dist/src/components/input-helper/constants.ts +0 -11
  159. package/dist/src/components/input-helper/index.ts +0 -1
  160. package/dist/src/components/input-label/InputLabel.stories.tsx +0 -15
  161. package/dist/src/components/input-label/InputLabel.test.tsx +0 -86
  162. package/dist/src/components/input-label/InputLabel.tsx +0 -59
  163. package/dist/src/components/input-label/__snapshots__/InputLabel.test.tsx.snap +0 -10
  164. package/dist/src/components/input-label/index.ts +0 -1
  165. package/dist/src/components/lightbox/Lightbox.stories.tsx +0 -83
  166. package/dist/src/components/lightbox/Lightbox.test.tsx +0 -30
  167. package/dist/src/components/lightbox/Lightbox.tsx +0 -153
  168. package/dist/src/components/lightbox/__snapshots__/Lightbox.test.tsx.snap +0 -194
  169. package/dist/src/components/lightbox/index.ts +0 -1
  170. package/dist/src/components/link/Link.stories.tsx +0 -141
  171. package/dist/src/components/link/Link.test.tsx +0 -60
  172. package/dist/src/components/link/Link.tsx +0 -156
  173. package/dist/src/components/link/__snapshots__/Link.test.tsx.snap +0 -29
  174. package/dist/src/components/link/index.ts +0 -1
  175. package/dist/src/components/link-preview/LinkPreview.stories.tsx +0 -88
  176. package/dist/src/components/link-preview/LinkPreview.test.tsx +0 -102
  177. package/dist/src/components/link-preview/LinkPreview.tsx +0 -158
  178. package/dist/src/components/link-preview/index.ts +0 -1
  179. package/dist/src/components/list/List.stories.tsx +0 -141
  180. package/dist/src/components/list/List.test.tsx +0 -29
  181. package/dist/src/components/list/List.tsx +0 -94
  182. package/dist/src/components/list/ListDivider.stories.tsx +0 -7
  183. package/dist/src/components/list/ListDivider.test.tsx +0 -29
  184. package/dist/src/components/list/ListDivider.tsx +0 -42
  185. package/dist/src/components/list/ListItem.stories.tsx +0 -62
  186. package/dist/src/components/list/ListItem.test.tsx +0 -29
  187. package/dist/src/components/list/ListItem.tsx +0 -154
  188. package/dist/src/components/list/ListSubheader.stories.tsx +0 -8
  189. package/dist/src/components/list/ListSubheader.test.tsx +0 -29
  190. package/dist/src/components/list/ListSubheader.tsx +0 -43
  191. package/dist/src/components/list/__snapshots__/List.test.tsx.snap +0 -360
  192. package/dist/src/components/list/__snapshots__/ListDivider.test.tsx.snap +0 -7
  193. package/dist/src/components/list/__snapshots__/ListItem.test.tsx.snap +0 -160
  194. package/dist/src/components/list/__snapshots__/ListSubheader.test.tsx.snap +0 -9
  195. package/dist/src/components/list/index.ts +0 -4
  196. package/dist/src/components/list/useInteractiveList.tsx +0 -202
  197. package/dist/src/components/message/Message.stories.tsx +0 -27
  198. package/dist/src/components/message/Message.test.tsx +0 -76
  199. package/dist/src/components/message/Message.tsx +0 -74
  200. package/dist/src/components/message/__snapshots__/Message.test.tsx.snap +0 -15
  201. package/dist/src/components/message/index.ts +0 -1
  202. package/dist/src/components/mosaic/Mosaic.stories.tsx +0 -85
  203. package/dist/src/components/mosaic/Mosaic.test.tsx +0 -120
  204. package/dist/src/components/mosaic/Mosaic.tsx +0 -95
  205. package/dist/src/components/mosaic/__snapshots__/Mosaic.test.tsx.snap +0 -357
  206. package/dist/src/components/mosaic/index.ts +0 -1
  207. package/dist/src/components/notification/Notification.test.tsx +0 -108
  208. package/dist/src/components/notification/Notification.tsx +0 -130
  209. package/dist/src/components/notification/Notifications.stories.tsx +0 -77
  210. package/dist/src/components/notification/__snapshots__/Notification.test.tsx.snap +0 -34
  211. package/dist/src/components/notification/constants.ts +0 -28
  212. package/dist/src/components/notification/index.ts +0 -1
  213. package/dist/src/components/popover/Popover.stories.tsx +0 -386
  214. package/dist/src/components/popover/Popover.test.tsx +0 -30
  215. package/dist/src/components/popover/Popover.tsx +0 -382
  216. package/dist/src/components/popover/__snapshots__/Popover.test.tsx.snap +0 -343
  217. package/dist/src/components/popover/index.ts +0 -1
  218. package/dist/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -75
  219. package/dist/src/components/popover-dialog/PopoverDialog.test.tsx +0 -65
  220. package/dist/src/components/popover-dialog/PopoverDialog.tsx +0 -65
  221. package/dist/src/components/popover-dialog/index.tsx +0 -1
  222. package/dist/src/components/post-block/PostBlock.test.tsx +0 -28
  223. package/dist/src/components/post-block/PostBlock.tsx +0 -123
  224. package/dist/src/components/post-block/__snapshots__/PostBlock.test.tsx.snap +0 -139
  225. package/dist/src/components/post-block/index.ts +0 -1
  226. package/dist/src/components/progress/Progress.tsx +0 -68
  227. package/dist/src/components/progress/ProgressCircular.stories.tsx +0 -18
  228. package/dist/src/components/progress/ProgressCircular.test.tsx +0 -49
  229. package/dist/src/components/progress/ProgressCircular.tsx +0 -68
  230. package/dist/src/components/progress/ProgressLinear.stories.tsx +0 -8
  231. package/dist/src/components/progress/ProgressLinear.test.tsx +0 -37
  232. package/dist/src/components/progress/ProgressLinear.tsx +0 -52
  233. package/dist/src/components/progress/index.ts +0 -3
  234. package/dist/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
  235. package/dist/src/components/progress-tracker/ProgressTracker.test.tsx +0 -57
  236. package/dist/src/components/progress-tracker/ProgressTracker.tsx +0 -89
  237. package/dist/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -42
  238. package/dist/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -66
  239. package/dist/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -128
  240. package/dist/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
  241. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -73
  242. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -67
  243. package/dist/src/components/progress-tracker/__snapshots__/ProgressTracker.test.tsx.snap +0 -41
  244. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStep.test.tsx.snap +0 -141
  245. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStepPanel.test.tsx.snap +0 -25
  246. package/dist/src/components/progress-tracker/index.ts +0 -4
  247. package/dist/src/components/radio-button/RadioButton.stories.tsx +0 -28
  248. package/dist/src/components/radio-button/RadioButton.test.tsx +0 -123
  249. package/dist/src/components/radio-button/RadioButton.tsx +0 -141
  250. package/dist/src/components/radio-button/RadioGroup.stories.tsx +0 -42
  251. package/dist/src/components/radio-button/RadioGroup.test.tsx +0 -77
  252. package/dist/src/components/radio-button/RadioGroup.tsx +0 -52
  253. package/dist/src/components/radio-button/__snapshots__/RadioButton.test.tsx.snap +0 -113
  254. package/dist/src/components/radio-button/__snapshots__/RadioGroup.test.tsx.snap +0 -26
  255. package/dist/src/components/radio-button/index.ts +0 -2
  256. package/dist/src/components/select/Select.stories.tsx +0 -399
  257. package/dist/src/components/select/Select.test.tsx +0 -359
  258. package/dist/src/components/select/Select.tsx +0 -193
  259. package/dist/src/components/select/SelectMultiple.stories.tsx +0 -227
  260. package/dist/src/components/select/SelectMultiple.test.tsx +0 -405
  261. package/dist/src/components/select/SelectMultiple.tsx +0 -198
  262. package/dist/src/components/select/WithSelectContext.tsx +0 -143
  263. package/dist/src/components/select/__snapshots__/Select.test.tsx.snap +0 -43
  264. package/dist/src/components/select/__snapshots__/SelectMultiple.test.tsx.snap +0 -87
  265. package/dist/src/components/select/constants.ts +0 -53
  266. package/dist/src/components/select/index.ts +0 -2
  267. package/dist/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
  268. package/dist/src/components/side-navigation/SideNavigation.test.tsx +0 -52
  269. package/dist/src/components/side-navigation/SideNavigation.tsx +0 -54
  270. package/dist/src/components/side-navigation/SideNavigationItem.test.tsx +0 -175
  271. package/dist/src/components/side-navigation/SideNavigationItem.tsx +0 -162
  272. package/dist/src/components/side-navigation/__snapshots__/SideNavigation.test.tsx.snap +0 -7
  273. package/dist/src/components/side-navigation/__snapshots__/SideNavigationItem.test.tsx.snap +0 -30
  274. package/dist/src/components/side-navigation/index.ts +0 -2
  275. package/dist/src/components/skeleton/SkeletonCircle.stories.tsx +0 -25
  276. package/dist/src/components/skeleton/SkeletonCircle.test.tsx +0 -28
  277. package/dist/src/components/skeleton/SkeletonCircle.tsx +0 -52
  278. package/dist/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -107
  279. package/dist/src/components/skeleton/SkeletonRectangle.test.tsx +0 -28
  280. package/dist/src/components/skeleton/SkeletonRectangle.tsx +0 -78
  281. package/dist/src/components/skeleton/SkeletonTypography.stories.tsx +0 -26
  282. package/dist/src/components/skeleton/SkeletonTypography.test.tsx +0 -28
  283. package/dist/src/components/skeleton/SkeletonTypography.tsx +0 -57
  284. package/dist/src/components/skeleton/__snapshots__/SkeletonCircle.test.tsx.snap +0 -54
  285. package/dist/src/components/skeleton/__snapshots__/SkeletonRectangle.test.tsx.snap +0 -177
  286. package/dist/src/components/skeleton/__snapshots__/SkeletonTypography.test.tsx.snap +0 -174
  287. package/dist/src/components/skeleton/index.ts +0 -3
  288. package/dist/src/components/slider/Slider.stories.tsx +0 -29
  289. package/dist/src/components/slider/Slider.test.tsx +0 -31
  290. package/dist/src/components/slider/Slider.tsx +0 -299
  291. package/dist/src/components/slider/__snapshots__/Slider.test.tsx.snap +0 -122
  292. package/dist/src/components/slider/index.ts +0 -2
  293. package/dist/src/components/slideshow/Slides.tsx +0 -124
  294. package/dist/src/components/slideshow/Slideshow.stories.tsx +0 -212
  295. package/dist/src/components/slideshow/Slideshow.test.tsx +0 -39
  296. package/dist/src/components/slideshow/Slideshow.tsx +0 -170
  297. package/dist/src/components/slideshow/SlideshowControls.stories.tsx +0 -112
  298. package/dist/src/components/slideshow/SlideshowControls.tsx +0 -241
  299. package/dist/src/components/slideshow/SlideshowItem.tsx +0 -52
  300. package/dist/src/components/slideshow/SlideshowItemGroup.tsx +0 -64
  301. package/dist/src/components/slideshow/__snapshots__/Slideshow.test.tsx.snap +0 -157
  302. package/dist/src/components/slideshow/constants.ts +0 -24
  303. package/dist/src/components/slideshow/index.ts +0 -4
  304. package/dist/src/components/slideshow/useKeyNavigate.ts +0 -28
  305. package/dist/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
  306. package/dist/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
  307. package/dist/src/components/slideshow/useSwipeNavigate.ts +0 -18
  308. package/dist/src/components/switch/Switch.stories.tsx +0 -36
  309. package/dist/src/components/switch/Switch.test.tsx +0 -189
  310. package/dist/src/components/switch/Switch.tsx +0 -141
  311. package/dist/src/components/switch/__snapshots__/Switch.test.tsx.snap +0 -179
  312. package/dist/src/components/switch/index.ts +0 -1
  313. package/dist/src/components/table/Table.test.tsx +0 -28
  314. package/dist/src/components/table/Table.tsx +0 -59
  315. package/dist/src/components/table/TableBody.test.tsx +0 -22
  316. package/dist/src/components/table/TableBody.tsx +0 -44
  317. package/dist/src/components/table/TableCell.test.tsx +0 -23
  318. package/dist/src/components/table/TableCell.tsx +0 -125
  319. package/dist/src/components/table/TableHeader.test.tsx +0 -22
  320. package/dist/src/components/table/TableHeader.tsx +0 -50
  321. package/dist/src/components/table/TableRow.test.tsx +0 -22
  322. package/dist/src/components/table/TableRow.tsx +0 -68
  323. package/dist/src/components/table/__snapshots__/Table.test.tsx.snap +0 -263
  324. package/dist/src/components/table/index.ts +0 -5
  325. package/dist/src/components/tabs/Tab.test.tsx +0 -116
  326. package/dist/src/components/tabs/Tab.tsx +0 -120
  327. package/dist/src/components/tabs/TabList.test.tsx +0 -80
  328. package/dist/src/components/tabs/TabList.tsx +0 -82
  329. package/dist/src/components/tabs/TabPanel.test.tsx +0 -74
  330. package/dist/src/components/tabs/TabPanel.tsx +0 -65
  331. package/dist/src/components/tabs/TabProvider.test.tsx +0 -42
  332. package/dist/src/components/tabs/TabProvider.tsx +0 -59
  333. package/dist/src/components/tabs/Tabs.stories.tsx +0 -134
  334. package/dist/src/components/tabs/__snapshots__/Tab.test.tsx.snap +0 -62
  335. package/dist/src/components/tabs/__snapshots__/TabList.test.tsx.snap +0 -22
  336. package/dist/src/components/tabs/__snapshots__/TabPanel.test.tsx.snap +0 -25
  337. package/dist/src/components/tabs/index.ts +0 -4
  338. package/dist/src/components/tabs/state.ts +0 -116
  339. package/dist/src/components/tabs/test.mocks.ts +0 -33
  340. package/dist/src/components/text/Text.stories.jsx +0 -75
  341. package/dist/src/components/text/Text.test.tsx +0 -108
  342. package/dist/src/components/text/Text.tsx +0 -121
  343. package/dist/src/components/text/index.ts +0 -1
  344. package/dist/src/components/text-field/TextField.stories.tsx +0 -169
  345. package/dist/src/components/text-field/TextField.test.tsx +0 -171
  346. package/dist/src/components/text-field/TextField.tsx +0 -432
  347. package/dist/src/components/text-field/__snapshots__/TextField.test.tsx.snap +0 -42
  348. package/dist/src/components/text-field/index.ts +0 -1
  349. package/dist/src/components/thumbnail/Thumbnail.stories.tsx +0 -510
  350. package/dist/src/components/thumbnail/Thumbnail.test.tsx +0 -46
  351. package/dist/src/components/thumbnail/Thumbnail.tsx +0 -222
  352. package/dist/src/components/thumbnail/__snapshots__/Thumbnail.test.tsx.snap +0 -130
  353. package/dist/src/components/thumbnail/index.ts +0 -3
  354. package/dist/src/components/thumbnail/types.ts +0 -39
  355. package/dist/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
  356. package/dist/src/components/thumbnail/useFocusPointStyle.tsx +0 -111
  357. package/dist/src/components/thumbnail/useImageLoad.ts +0 -40
  358. package/dist/src/components/toolbar/Toolbar.tsx +0 -67
  359. package/dist/src/components/toolbar/index.ts +0 -1
  360. package/dist/src/components/tooltip/Tooltip.stories.tsx +0 -172
  361. package/dist/src/components/tooltip/Tooltip.test.tsx +0 -105
  362. package/dist/src/components/tooltip/Tooltip.tsx +0 -122
  363. package/dist/src/components/tooltip/__snapshots__/Tooltip.test.tsx.snap +0 -233
  364. package/dist/src/components/tooltip/index.ts +0 -1
  365. package/dist/src/components/tooltip/useInjectTooltipRef.tsx +0 -44
  366. package/dist/src/components/tooltip/useTooltipOpen.tsx +0 -113
  367. package/dist/src/components/uploader/Uploader.test.tsx +0 -87
  368. package/dist/src/components/uploader/Uploader.tsx +0 -105
  369. package/dist/src/components/uploader/__snapshots__/Uploader.test.tsx.snap +0 -14
  370. package/dist/src/components/uploader/index.ts +0 -1
  371. package/dist/src/components/user-block/UserBlock.stories.tsx +0 -76
  372. package/dist/src/components/user-block/UserBlock.test.tsx +0 -38
  373. package/dist/src/components/user-block/UserBlock.tsx +0 -179
  374. package/dist/src/components/user-block/__snapshots__/UserBlock.test.tsx.snap +0 -362
  375. package/dist/src/components/user-block/index.ts +0 -1
  376. package/dist/src/constants.ts +0 -17
  377. package/dist/src/hooks/useBooleanState.tsx +0 -13
  378. package/dist/src/hooks/useCallbackOnEscape.ts +0 -34
  379. package/dist/src/hooks/useChipGroupNavigation.tsx +0 -75
  380. package/dist/src/hooks/useClickAway.tsx +0 -47
  381. package/dist/src/hooks/useDisableBodyScroll.ts +0 -28
  382. package/dist/src/hooks/useEventCallback.tsx +0 -17
  383. package/dist/src/hooks/useFocus.tsx +0 -21
  384. package/dist/src/hooks/useFocusTrap.ts +0 -85
  385. package/dist/src/hooks/useFocusWithin.ts +0 -33
  386. package/dist/src/hooks/useInfiniteScroll.tsx +0 -60
  387. package/dist/src/hooks/useIntersectionObserver.tsx +0 -43
  388. package/dist/src/hooks/useInterval.tsx +0 -31
  389. package/dist/src/hooks/useKeyboardListNavigation.tsx +0 -204
  390. package/dist/src/hooks/useListenFocus.tsx +0 -26
  391. package/dist/src/hooks/useOnResize.ts +0 -41
  392. package/dist/src/hooks/useRovingTabIndex.tsx +0 -90
  393. package/dist/src/hooks/useSlideshowControls.ts +0 -243
  394. package/dist/src/hooks/useStopPropagation.ts +0 -21
  395. package/dist/src/hooks/useTransitionVisibility.ts +0 -54
  396. package/dist/src/index.ts +0 -58
  397. package/dist/src/stories/chromaticForceScreenSize.tsx +0 -7
  398. package/dist/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
  399. package/dist/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
  400. package/dist/src/stories/generated/Badge/Demos.stories.tsx +0 -9
  401. package/dist/src/stories/generated/Button/Demos.stories.tsx +0 -11
  402. package/dist/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
  403. package/dist/src/stories/generated/Chip/Demos.stories.tsx +0 -11
  404. package/dist/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
  405. package/dist/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
  406. package/dist/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
  407. package/dist/src/stories/generated/Divider/Demos.stories.tsx +0 -6
  408. package/dist/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
  409. package/dist/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
  410. package/dist/src/stories/generated/Flag/Demos.stories.tsx +0 -6
  411. package/dist/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
  412. package/dist/src/stories/generated/Heading/Demos.stories.tsx +0 -6
  413. package/dist/src/stories/generated/Icon/Demos.stories.tsx +0 -8
  414. package/dist/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
  415. package/dist/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
  416. package/dist/src/stories/generated/Link/Demos.stories.tsx +0 -8
  417. package/dist/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
  418. package/dist/src/stories/generated/List/Demos.stories.tsx +0 -11
  419. package/dist/src/stories/generated/Message/Demos.stories.tsx +0 -10
  420. package/dist/src/stories/generated/Mosaic/Demos.stories.tsx +0 -9
  421. package/dist/src/stories/generated/Notification/Demos.stories.tsx +0 -6
  422. package/dist/src/stories/generated/Popover/Demos.stories.tsx +0 -11
  423. package/dist/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
  424. package/dist/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
  425. package/dist/src/stories/generated/Progress/Demos.stories.tsx +0 -7
  426. package/dist/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
  427. package/dist/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
  428. package/dist/src/stories/generated/Select/Demos.stories.tsx +0 -14
  429. package/dist/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
  430. package/dist/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
  431. package/dist/src/stories/generated/Slider/Demos.stories.tsx +0 -9
  432. package/dist/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
  433. package/dist/src/stories/generated/Switch/Demos.stories.tsx +0 -6
  434. package/dist/src/stories/generated/Table/Demos.stories.tsx +0 -6
  435. package/dist/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
  436. package/dist/src/stories/generated/TextField/Demos.stories.tsx +0 -19
  437. package/dist/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
  438. package/dist/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
  439. package/dist/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
  440. package/dist/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
  441. package/dist/src/stories/generated/UserBlock/Demos.stories.tsx +0 -10
  442. package/dist/src/stories/knobs/buttonKnob.ts +0 -9
  443. package/dist/src/stories/knobs/emphasisKnob.ts +0 -8
  444. package/dist/src/stories/knobs/enumKnob.ts +0 -14
  445. package/dist/src/stories/knobs/focusKnob.ts +0 -3
  446. package/dist/src/stories/knobs/image.ts +0 -69
  447. package/dist/src/stories/knobs/lorem.ts +0 -59
  448. package/dist/src/stories/knobs/sizeKnob.ts +0 -5
  449. package/dist/src/stories/knobs/thumbnailsKnob.ts +0 -9
  450. package/dist/src/stories/utils/CustomLink.tsx +0 -7
  451. package/dist/src/stories/withResizableBox.tsx +0 -18
  452. package/dist/src/testing/utils/commonTestsSuite.ts +0 -71
  453. package/dist/src/testing/utils/commonTestsSuiteRTL.ts +0 -55
  454. package/dist/src/testing/utils/index.ts +0 -4
  455. package/dist/src/testing/utils/itShouldRenderStories.tsx +0 -103
  456. package/dist/src/testing/utils/queries.ts +0 -19
  457. package/dist/src/untypped-modules.d.ts +0 -7
  458. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -58
  459. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -65
  460. package/dist/src/utils/ClickAwayProvider/index.ts +0 -1
  461. package/dist/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
  462. package/dist/src/utils/MaterialThemeSwitcher/index.ts +0 -1
  463. package/dist/src/utils/browserDoesNotSupportHover.test.js +0 -24
  464. package/dist/src/utils/browserDoesNotSupportHover.ts +0 -2
  465. package/dist/src/utils/clamp.ts +0 -17
  466. package/dist/src/utils/className.ts +0 -44
  467. package/dist/src/utils/event.ts +0 -1
  468. package/dist/src/utils/flattenChildren.test.tsx +0 -58
  469. package/dist/src/utils/flattenChildren.ts +0 -27
  470. package/dist/src/utils/focus/constants.ts +0 -5
  471. package/dist/src/utils/focus/getFirstAndLastFocusable.test.ts +0 -134
  472. package/dist/src/utils/focus/getFirstAndLastFocusable.ts +0 -21
  473. package/dist/src/utils/focus/getFocusableElements.test.ts +0 -151
  474. package/dist/src/utils/focus/getFocusableElements.ts +0 -7
  475. package/dist/src/utils/index.ts +0 -5
  476. package/dist/src/utils/isInternetExplorer.ts +0 -15
  477. package/dist/src/utils/makeListenerTowerContext.ts +0 -32
  478. package/dist/src/utils/mergeRefs.ts +0 -22
  479. package/dist/src/utils/partitionMulti.ts +0 -28
  480. package/dist/src/utils/renderLink.tsx +0 -17
  481. package/dist/src/utils/type.ts +0 -113
  482. package/dist/src/utils/userHasReducedMotion.ts +0 -7
  483. package/dist/src/utils/utils.test.ts +0 -48
  484. package/jest/__mocks__/@storybook/addon-actions.js +0 -3
  485. package/jest/__mocks__/@storybook/addon-knobs.js +0 -6
  486. package/jest/__mocks__/emptyFileMockTransformer.js +0 -8
  487. package/jest/__mocks__/emptyModuleMock.js +0 -1
  488. package/jest/configure.js +0 -6
  489. package/jest/index.js +0 -36
  490. package/jest/transform.js +0 -6
  491. package/rollup.config.js +0 -98
  492. package/storybook/build +0 -4
  493. package/storybook/generate-demo-stories.js +0 -59
  494. package/storybook/main.js +0 -67
  495. package/storybook/package.json +0 -13
  496. package/storybook/preview.js +0 -11
  497. package/storybook/start +0 -4
  498. package/storybook/story-block/StoryBlock.tsx +0 -49
  499. package/storybook/story-block/decorator.jsx +0 -7
  500. package/storybook/story-block/index.scss +0 -27
  501. package/storybook/yarn.lock +0 -13192
  502. package/tsconfig.json +0 -3
@@ -1,152 +0,0 @@
1
- import React, { createRef } from 'react';
2
- import { mount, shallow } from 'enzyme';
3
- import 'jest-enzyme';
4
- import { commonTestsSuite } from '@lumx/react/testing/utils';
5
-
6
- import { GenericBlock, GenericBlockProps } from '.';
7
-
8
- const CLASSNAME = GenericBlock.className as string;
9
-
10
- /**
11
- * Mounts the component and returns common DOM elements / data needed in multiple tests further down.
12
- */
13
- const setup = (props: Partial<GenericBlockProps> = {}, shallowRendering = true) => {
14
- const renderer: any = shallowRendering ? shallow : mount;
15
- const wrapper: any = renderer(<GenericBlock {...(props as any)} />);
16
- return { props, wrapper };
17
- };
18
-
19
- describe(`<${GenericBlock.displayName}>`, () => {
20
- // 1. Test render via snapshot.
21
- describe('Snapshots and structure', () => {
22
- it('should render default', () => {
23
- const wrapper = shallow(
24
- <GenericBlock figure="figure" actions="actions">
25
- Content
26
- </GenericBlock>,
27
- );
28
-
29
- expect(wrapper.prop('gap')).toBe('big');
30
- expect(wrapper.prop('orientation')).toBe('horizontal');
31
-
32
- const figure = wrapper.find('.lumx-generic-block__figure');
33
- expect(figure).toHaveLength(1);
34
-
35
- const content = wrapper.find('.lumx-generic-block__content');
36
- expect(content).toHaveLength(1);
37
- expect(content.prop('fillSpace')).toBe(true);
38
- expect(content.prop('orientation')).toBe('vertical');
39
-
40
- const actions = wrapper.find('.lumx-generic-block__actions');
41
- expect(actions).toHaveLength(1);
42
- });
43
-
44
- it('should forward vAlign & hAlign', () => {
45
- const wrapper = shallow(
46
- <GenericBlock figure="figure" actions="actions" vAlign="left" hAlign="bottom">
47
- Content
48
- </GenericBlock>,
49
- );
50
-
51
- expect(wrapper.prop('vAlign')).toBe('left');
52
- expect(wrapper.prop('hAlign')).toBe('bottom');
53
-
54
- const figure = wrapper.find('.lumx-generic-block__figure');
55
- expect(figure).toHaveLength(1);
56
- expect(figure.prop('vAlign')).toBe('left');
57
- expect(figure.prop('hAlign')).toBe('bottom');
58
-
59
- const content = wrapper.find('.lumx-generic-block__content');
60
- expect(content).toHaveLength(1);
61
- expect(content.prop('vAlign')).toBe('left');
62
- expect(content.prop('hAlign')).toBe('bottom');
63
-
64
- const actions = wrapper.find('.lumx-generic-block__actions');
65
- expect(actions).toHaveLength(1);
66
- expect(actions.prop('vAlign')).toBe('left');
67
- expect(actions.prop('hAlign')).toBe('bottom');
68
- });
69
-
70
- it('should combine figure props', () => {
71
- const wrapper = shallow(
72
- <GenericBlock figure="Figure 1" figureProps={{ className: 'figure1', vAlign: 'left' }}>
73
- <GenericBlock.Figure className="figure2" fillSpace>
74
- Figure 2
75
- </GenericBlock.Figure>
76
- </GenericBlock>,
77
- );
78
-
79
- const figure = wrapper.find('.lumx-generic-block__figure');
80
- expect(figure).toHaveClassName('figure1');
81
- expect(figure).toHaveClassName('figure2');
82
- expect(figure.prop('fillSpace')).toBe(true);
83
- expect(figure.prop('vAlign')).toBe('left');
84
- expect(figure).toHaveText('Figure 1Figure 2');
85
-
86
- expect(wrapper.find('.lumx-generic-block__content')).toHaveLength(0);
87
- expect(wrapper.find('.lumx-generic-block__actions')).toHaveLength(0);
88
- });
89
-
90
- it('should combine content props', () => {
91
- const wrapper = shallow(
92
- <GenericBlock contentProps={{ className: 'content1', vAlign: 'left' }}>
93
- Content 1
94
- <GenericBlock.Content className="content2" fillSpace>
95
- Content 2
96
- </GenericBlock.Content>
97
- </GenericBlock>,
98
- );
99
-
100
- const content = wrapper.find('.lumx-generic-block__content');
101
- expect(content).toHaveClassName('content1');
102
- expect(content).toHaveClassName('content2');
103
- expect(content.prop('fillSpace')).toBe(true);
104
- expect(content.prop('vAlign')).toBe('left');
105
- expect(content).toHaveText('Content 2Content 1');
106
-
107
- expect(wrapper.find('.lumx-generic-block__figure')).toHaveLength(0);
108
- expect(wrapper.find('.lumx-generic-block__actions')).toHaveLength(0);
109
- });
110
-
111
- it('should combine actions props', () => {
112
- const wrapper = shallow(
113
- <GenericBlock actions="Actions 1" actionsProps={{ className: 'actions1', vAlign: 'left' }}>
114
- <GenericBlock.Actions className="actions2" fillSpace>
115
- Actions 2
116
- </GenericBlock.Actions>
117
- </GenericBlock>,
118
- );
119
-
120
- const actions = wrapper.find('.lumx-generic-block__actions');
121
- expect(actions).toHaveClassName('actions1');
122
- expect(actions).toHaveClassName('actions2');
123
- expect(actions.prop('fillSpace')).toBe(true);
124
- expect(actions.prop('vAlign')).toBe('left');
125
- expect(actions).toHaveText('Actions 1Actions 2');
126
-
127
- expect(wrapper.find('.lumx-generic-block__figure')).toHaveLength(0);
128
- expect(wrapper.find('.lumx-generic-block__content')).toHaveLength(0);
129
- });
130
-
131
- it('should forward refs', () => {
132
- const rootRef = createRef<HTMLDivElement>();
133
- const figureRef = createRef<HTMLDivElement>();
134
- const contentRef = createRef<HTMLDivElement>();
135
- const actionsRef = createRef<HTMLDivElement>();
136
- shallow(
137
- <GenericBlock ref={rootRef}>
138
- <GenericBlock.Figure ref={figureRef} />
139
- <GenericBlock.Content ref={contentRef} />
140
- <GenericBlock.Actions ref={actionsRef} />
141
- </GenericBlock>,
142
- );
143
- expect(rootRef.current).toBeDefined();
144
- expect(figureRef.current).toBeDefined();
145
- expect(contentRef.current).toBeDefined();
146
- expect(actionsRef.current).toBeDefined();
147
- });
148
- });
149
-
150
- // Common tests suite.
151
- commonTestsSuite(setup, { className: 'wrapper', prop: 'wrapper' }, { className: CLASSNAME });
152
- });
@@ -1,222 +0,0 @@
1
- import React, { Children, forwardRef, ReactElement, ReactNode } from 'react';
2
- import classNames from 'classnames';
3
- import isEmpty from 'lodash/isEmpty';
4
- import noop from 'lodash/noop';
5
- import { Comp, isComponentType } from '@lumx/react/utils/type';
6
- import { getRootClassName } from '@lumx/react/utils/className';
7
- import { partitionMulti } from '@lumx/react/utils/partitionMulti';
8
- import { Orientation, Size, FlexBox, FlexBoxProps } from '@lumx/react';
9
- import { GenericBlockGapSize } from '@lumx/react/components/generic-block/constants';
10
-
11
- export interface GenericBlockProps extends FlexBoxProps {
12
- /**
13
- * Component to use as visual element.
14
- */
15
- figure?: ReactNode;
16
- /**
17
- * Actions to set after the main content.
18
- */
19
- actions?: ReactNode;
20
- /**
21
- * Main content to display or sections components
22
- * ({@see GenericBlock.Figure}, {@see GenericBlock.Content} & {@see GenericBlock.Actions})
23
- */
24
- children: ReactNode;
25
- /**
26
- * Orientation of the 3 sections
27
- */
28
- orientation?: FlexBoxProps['orientation'];
29
- /**
30
- * Horizontal alignment.
31
- */
32
- hAlign?: FlexBoxProps['hAlign'];
33
- /**
34
- * Vertical alignment.
35
- */
36
- vAlign?: FlexBoxProps['vAlign'];
37
- /**
38
- * The props to forward to the content.
39
- * By default, the content will have the same alignment as wrapper.
40
- */
41
- contentProps?: Omit<FlexBoxProps, 'children'>;
42
- /**
43
- * props to forward to the actions element.
44
- */
45
- actionsProps?: Omit<FlexBoxProps, 'children'>;
46
- /**
47
- * props to forward to the figure element.
48
- */
49
- figureProps?: Omit<FlexBoxProps, 'children'>;
50
- /**
51
- * Gap space between sections.
52
- */
53
- gap?: GenericBlockGapSize;
54
- }
55
-
56
- /**
57
- * Component display name.
58
- */
59
- const COMPONENT_NAME = 'GenericBlock';
60
-
61
- /**
62
- * Component default class name and class prefix.
63
- */
64
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
65
-
66
- /**
67
- * Component default props.
68
- */
69
- const DEFAULT_PROPS: Partial<GenericBlockProps> = {
70
- gap: Size.big,
71
- orientation: Orientation.horizontal,
72
- };
73
-
74
- type BaseGenericBlock = Comp<GenericBlockProps, HTMLDivElement>;
75
-
76
- interface GenericBlockSectionProps extends FlexBoxProps {
77
- /**
78
- * Gap space between items.
79
- */
80
- gap?: GenericBlockGapSize;
81
- }
82
-
83
- interface GenericBlock extends BaseGenericBlock {
84
- /**
85
- * Use `GenericBlock.Figure` component as children of the `GenericBlock` component as an alternative way to inject
86
- * the "figure" section of the block (instead of using `figure` and `figureProps` props).
87
- */
88
- Figure: Comp<GenericBlockSectionProps>;
89
- /**
90
- * Use `GenericBlock.Content` component as children of the `GenericBlock` component as an alternative way to inject
91
- * the "content" section of the block (instead of using `content` and `contentProps` props).
92
- */
93
- Content: Comp<GenericBlockSectionProps>;
94
- /**
95
- * Use `GenericBlock.Actions` component as children of the `GenericBlock` component as an alternative way to inject
96
- * the "actions" section of the block (instead of using `actions` and `actionsProps` props).
97
- */
98
- Actions: Comp<GenericBlockSectionProps>;
99
- }
100
-
101
- const Figure = noop.bind({}) as Comp<FlexBoxProps>;
102
- const isFigure = isComponentType(Figure);
103
-
104
- const Content = noop.bind({}) as Comp<FlexBoxProps>;
105
- const isContent = isComponentType(Content);
106
-
107
- const Actions = noop.bind({}) as Comp<FlexBoxProps>;
108
- const isActions = isComponentType(Actions);
109
-
110
- /**
111
- * The GenericBlock is a layout component made of 3 sections that can be
112
- * displayed either horizontally of vertically with the same gap between each section.
113
- *
114
- * The sections are:
115
- * - `Figure` => A visual element to display before the main content.
116
- * - `Content` => The main content displayed
117
- * - `Actions` => One or more actions to set after the element.
118
- *
119
- * @see https://www.figma.com/file/lzzrQmsfaXRaOyRfoEogPZ/DS%3A-playground?node-id=1%3A4076
120
- */
121
- const BaseGenericBlock: BaseGenericBlock = forwardRef((props, ref) => {
122
- const {
123
- className,
124
- figure,
125
- figureProps,
126
- children,
127
- actions,
128
- actionsProps,
129
- gap,
130
- orientation,
131
- contentProps,
132
- ...forwardedProps
133
- } = props;
134
-
135
- const sections = React.useMemo(() => {
136
- // Split children by section type
137
- const [[figureChild], [contentChild], [actionsChild], ...otherChildren] = partitionMulti(
138
- Children.toArray(children),
139
- [isFigure, isContent, isActions],
140
- );
141
- return {
142
- figureChild,
143
- figureChildProps: (figureChild as ReactElement)?.props,
144
- contentChild,
145
- contentChildProps: (contentChild as ReactElement)?.props,
146
- actionsChild,
147
- actionsChildProps: (actionsChild as ReactElement)?.props,
148
- otherChildren: otherChildren.filter((child) => !isEmpty(child)),
149
- };
150
- }, [children]);
151
-
152
- return (
153
- <FlexBox
154
- ref={ref}
155
- className={classNames(className, CLASSNAME)}
156
- gap={gap}
157
- orientation={orientation}
158
- {...forwardedProps}
159
- >
160
- {(figure || sections.figureChildProps?.children) && (
161
- <FlexBox
162
- ref={(sections.figureChild as any)?.ref}
163
- vAlign={forwardedProps.vAlign}
164
- hAlign={forwardedProps.hAlign}
165
- {...figureProps}
166
- {...sections.figureChildProps}
167
- className={classNames(
168
- figureProps?.className,
169
- sections.figureChildProps?.className,
170
- `${CLASSNAME}__figure`,
171
- )}
172
- >
173
- {figure}
174
- {sections.figureChildProps?.children}
175
- </FlexBox>
176
- )}
177
-
178
- {(sections.contentChildProps?.children || sections.otherChildren.length > 0) && (
179
- <FlexBox
180
- ref={(sections.contentChild as any)?.ref}
181
- orientation={Orientation.vertical}
182
- fillSpace
183
- vAlign={forwardedProps.vAlign}
184
- hAlign={forwardedProps.hAlign}
185
- {...contentProps}
186
- {...sections.contentChildProps}
187
- className={classNames(
188
- contentProps?.className,
189
- sections.contentChildProps?.className,
190
- `${CLASSNAME}__content`,
191
- )}
192
- >
193
- {sections.contentChildProps?.children}
194
- {sections.otherChildren}
195
- </FlexBox>
196
- )}
197
-
198
- {(actions || sections.actionsChildProps?.children) && (
199
- <FlexBox
200
- ref={(sections.actionsChild as any)?.ref}
201
- vAlign={forwardedProps.vAlign}
202
- hAlign={forwardedProps.hAlign}
203
- {...actionsProps}
204
- {...sections.actionsChildProps}
205
- className={classNames(
206
- actionsProps?.className,
207
- sections.actionsChildProps?.className,
208
- `${CLASSNAME}__actions`,
209
- )}
210
- >
211
- {actions}
212
- {sections.actionsChildProps?.children}
213
- </FlexBox>
214
- )}
215
- </FlexBox>
216
- );
217
- });
218
- BaseGenericBlock.displayName = COMPONENT_NAME;
219
- BaseGenericBlock.className = CLASSNAME;
220
- BaseGenericBlock.defaultProps = DEFAULT_PROPS;
221
-
222
- export const GenericBlock: GenericBlock = Object.assign(BaseGenericBlock, { Figure, Content, Actions });
@@ -1,9 +0,0 @@
1
- import pick from 'lodash/pick';
2
- import { Size } from '@lumx/react';
3
- import { ValueOf } from '@lumx/react/utils/type';
4
-
5
- /**
6
- * Accepted gap sizes for the generic block.
7
- */
8
- export const GenericBlockGapSize = pick(Size, ['tiny', 'regular', 'medium', 'big', 'huge']);
9
- export type GenericBlockGapSize = ValueOf<typeof GenericBlockGapSize>;
@@ -1,2 +0,0 @@
1
- export * from './GenericBlock';
2
- export { GenericBlockGapSize } from './constants';
@@ -1,73 +0,0 @@
1
- import React, { forwardRef } from 'react';
2
-
3
- import classNames from 'classnames';
4
-
5
- import { Alignment, Orientation, Size } from '@lumx/react';
6
- import { Comp, GenericProps } from '@lumx/react/utils/type';
7
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
8
-
9
- type GridGutterSize = Extract<Size, 'regular' | 'big' | 'huge'>;
10
-
11
- /**
12
- * Defines the props of the component.
13
- */
14
- export interface GridProps extends GenericProps {
15
- /** Orientation. */
16
- orientation?: Orientation;
17
- /** Whether the children are wrapped or not. */
18
- wrap?: string;
19
- /** Vertical alignment. */
20
- vAlign?: Alignment;
21
- /** Horizontal alignment. */
22
- hAlign?: Alignment;
23
- /** Gutter size. */
24
- gutter?: GridGutterSize;
25
- }
26
-
27
- /**
28
- * Component display name.
29
- */
30
- const COMPONENT_NAME = 'Grid';
31
-
32
- /**
33
- * Component default class name and class prefix.
34
- */
35
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
36
-
37
- /**
38
- * Component default props.
39
- */
40
- const DEFAULT_PROPS: Partial<GridProps> = {
41
- orientation: Orientation.horizontal,
42
- wrap: 'nowrap',
43
- };
44
-
45
- /**
46
- * Grid component.
47
- *
48
- * @param props Component props.
49
- * @param ref Component ref.
50
- * @return React element.
51
- */
52
- export const Grid: Comp<GridProps, HTMLDivElement> = forwardRef((props, ref) => {
53
- const { children, className, gutter, hAlign, orientation, vAlign, wrap, ...forwardedProps } = props;
54
-
55
- return (
56
- <div
57
- ref={ref}
58
- {...forwardedProps}
59
- className={classNames(
60
- className,
61
- `${CLASSNAME}-container`,
62
- { [`${CLASSNAME}--h-align-${hAlign}`]: hAlign },
63
- { [`${CLASSNAME}--v-align-${vAlign}`]: vAlign },
64
- handleBasicClasses({ prefix: CLASSNAME, orientation, wrap, gutter }),
65
- )}
66
- >
67
- {children}
68
- </div>
69
- );
70
- });
71
- Grid.displayName = COMPONENT_NAME;
72
- Grid.className = CLASSNAME;
73
- Grid.defaultProps = DEFAULT_PROPS;
@@ -1,54 +0,0 @@
1
- import React, { forwardRef } from 'react';
2
-
3
- import classNames from 'classnames';
4
-
5
- import { Alignment } from '@lumx/react';
6
- import { Comp, GenericProps } from '@lumx/react/utils/type';
7
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
8
-
9
- type Columns = '1' | '2' | '3' | '4' | '5' | '6' | '7' | '8' | '9' | '10' | '11' | '12';
10
-
11
- /**
12
- * Defines the props of the component.
13
- */
14
- export interface GridItemProps extends GenericProps {
15
- /** Alignment. */
16
- align?: Alignment;
17
- /** Order. */
18
- order?: Columns;
19
- /** Width. */
20
- width?: Columns;
21
- }
22
-
23
- /**
24
- * Component display name.
25
- */
26
- const COMPONENT_NAME = 'GridItem';
27
-
28
- /**
29
- * Component default class name and class prefix.
30
- */
31
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
32
-
33
- /**
34
- * GridItem component.
35
- *
36
- * @param props Component props.
37
- * @param ref Component ref.
38
- * @return React element.
39
- */
40
- export const GridItem: Comp<GridItemProps, HTMLDivElement> = forwardRef((props, ref) => {
41
- const { children, className, width, align, order, ...forwardedProps } = props;
42
-
43
- return (
44
- <div
45
- ref={ref}
46
- {...forwardedProps}
47
- className={classNames(className, handleBasicClasses({ prefix: CLASSNAME, width, order, align }))}
48
- >
49
- {children}
50
- </div>
51
- );
52
- });
53
- GridItem.displayName = COMPONENT_NAME;
54
- GridItem.className = CLASSNAME;
@@ -1,2 +0,0 @@
1
- export * from './Grid';
2
- export * from './GridItem';
@@ -1,56 +0,0 @@
1
- import React from 'react';
2
-
3
- import { GridColumn } from '@lumx/react/components/grid-column/GridColumn';
4
-
5
- import range from 'lodash/range';
6
- import { Size } from '@lumx/react';
7
-
8
- const genericBlockStyle = { border: '1px solid red', padding: '2px 8px' };
9
-
10
- export default {
11
- title: 'LumX components/grid-column/GridColumn',
12
- argTypes: {
13
- nbItems: {
14
- control: 'number',
15
- defaultValue: 6,
16
- min: 0,
17
- },
18
- gap: {
19
- control: 'select',
20
- options: [Size.tiny, Size.regular, Size.big, Size.huge],
21
- defaultValue: Size.regular,
22
- },
23
- itemMinWidth: {
24
- control: 'number',
25
- defaultValue: 200,
26
- },
27
- maxColumns: {
28
- control: 'number',
29
- defaultValue: 4,
30
- },
31
- },
32
- args: {
33
- style: {
34
- overflow: 'hidden',
35
- resize: 'horizontal',
36
- },
37
- },
38
- };
39
-
40
- const getItems = (nb) =>
41
- range(nb).map((key) => (
42
- // eslint-disable-next-line react/jsx-key
43
- <div style={genericBlockStyle}>
44
- <h2>Column {key}</h2>
45
- <p>
46
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
47
- dolore magna aliqua. Nulla pharetra diam sit amet nisl suscipit adipiscing bibendum. Iaculis at erat
48
- pellentesque adipiscing commodo elit at imperdiet dui. Ultricies integer quis auctor elit sed vulputate.
49
- Mattis enim ut tellus elementum. Ipsum suspendisse ultrices gravida dictum fusce ut..
50
- </p>
51
- </div>
52
- ));
53
-
54
- const Template = ({ nbItems = 5, ...props }) => <GridColumn {...props}>{getItems(nbItems)}</GridColumn>;
55
-
56
- export const Default = Template.bind({});
@@ -1,58 +0,0 @@
1
- import React from 'react';
2
-
3
- import { commonTestsSuiteRTL } from '@lumx/react/testing/utils';
4
- import { render } from '@testing-library/react';
5
- import { getByClassName } from '@lumx/react/testing/utils/queries';
6
-
7
- import { GridColumn } from './index';
8
-
9
- const CLASSNAME = GridColumn.className;
10
-
11
- /**
12
- * Mounts the component and returns common DOM elements / data needed in multiple tests further down.
13
- */
14
- const setup = (propsOverride = {}) => {
15
- const props = { ...propsOverride };
16
- const { container } = render(
17
- <GridColumn {...props}>
18
- <p>Content 1</p>
19
- <p>Content 2</p>
20
- <p>Content 3</p>
21
- </GridColumn>,
22
- );
23
-
24
- const gridColumn = getByClassName(container, CLASSNAME);
25
-
26
- return { props, container, gridColumn };
27
- };
28
-
29
- describe(`<${GridColumn.displayName}>`, () => {
30
- it('should create default component', () => {
31
- const { gridColumn } = setup();
32
-
33
- expect(gridColumn).toBeInTheDocument();
34
- expect(gridColumn.children).toHaveLength(3);
35
- });
36
-
37
- describe('Props', () => {
38
- it('should override CSS props', () => {
39
- const { gridColumn } = setup({
40
- gap: 'regular',
41
- maxColumns: 10,
42
- itemMinWidth: 300,
43
- });
44
-
45
- expect(gridColumn).toHaveAttribute(
46
- 'style',
47
- '--lumx-grid-column-item-min-width: 300px; --lumx-grid-column-columns: 10; --lumx-grid-column-gap: var(--lumx-spacing-unit-regular);',
48
- );
49
- });
50
- });
51
-
52
- // Common tests suite.
53
- commonTestsSuiteRTL(setup, {
54
- baseClassName: CLASSNAME,
55
- forwardAttributes: 'gridColumn',
56
- forwardClassName: 'gridColumn',
57
- });
58
- });