@lumx/react 3.1.1 → 3.1.2

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