@lumx/react 3.1.1 → 3.1.3-alpha.0

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