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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (502) hide show
  1. package/{dist/CONTRIBUTING.md → CONTRIBUTING.md} +0 -0
  2. package/{dist/LICENSE.md → LICENSE.md} +0 -0
  3. package/{dist/_internal → _internal}/ClickAwayProvider.js +0 -0
  4. package/{dist/_internal → _internal}/ClickAwayProvider.js.map +0 -0
  5. package/{dist/_internal → _internal}/types.d.ts +1 -1
  6. package/{dist/index.d.ts → index.d.ts} +7 -7
  7. package/{dist/index.js → index.js} +0 -0
  8. package/{dist/index.js.map → index.js.map} +1 -1
  9. package/package.json +3 -3
  10. package/src/components/badge/Badge.tsx +2 -2
  11. package/src/components/button/ButtonRoot.tsx +2 -2
  12. package/src/components/chip/Chip.tsx +2 -2
  13. package/src/components/icon/Icon.tsx +2 -2
  14. package/src/components/link/Link.tsx +2 -2
  15. package/{dist/utils → utils}/index.d.ts +0 -0
  16. package/{dist/utils → utils}/index.js +0 -0
  17. package/{dist/utils → utils}/index.js.map +0 -0
  18. package/dist/README.md +0 -38
  19. package/dist/package.json +0 -117
  20. package/dist/src/components/alert-dialog/AlertDialog.stories.tsx +0 -196
  21. package/dist/src/components/alert-dialog/AlertDialog.test.tsx +0 -43
  22. package/dist/src/components/alert-dialog/AlertDialog.tsx +0 -185
  23. package/dist/src/components/alert-dialog/__snapshots__/AlertDialog.test.tsx.snap +0 -551
  24. package/dist/src/components/alert-dialog/index.ts +0 -1
  25. package/dist/src/components/autocomplete/Autocomplete.stories.tsx +0 -70
  26. package/dist/src/components/autocomplete/Autocomplete.test.tsx +0 -181
  27. package/dist/src/components/autocomplete/Autocomplete.tsx +0 -292
  28. package/dist/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -170
  29. package/dist/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -94
  30. package/dist/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
  31. package/dist/src/components/autocomplete/__mockData__/index.ts +0 -34
  32. package/dist/src/components/autocomplete/__snapshots__/Autocomplete.test.tsx.snap +0 -213
  33. package/dist/src/components/autocomplete/__snapshots__/AutocompleteMultiple.test.tsx.snap +0 -88
  34. package/dist/src/components/autocomplete/index.ts +0 -2
  35. package/dist/src/components/avatar/Avatar.stories.tsx +0 -92
  36. package/dist/src/components/avatar/Avatar.test.tsx +0 -39
  37. package/dist/src/components/avatar/Avatar.tsx +0 -112
  38. package/dist/src/components/avatar/__snapshots__/Avatar.test.tsx.snap +0 -681
  39. package/dist/src/components/avatar/index.ts +0 -1
  40. package/dist/src/components/badge/Badge.stories.tsx +0 -45
  41. package/dist/src/components/badge/Badge.test.tsx +0 -91
  42. package/dist/src/components/badge/Badge.tsx +0 -55
  43. package/dist/src/components/badge/__snapshots__/Badge.test.tsx.snap +0 -11
  44. package/dist/src/components/badge/index.ts +0 -1
  45. package/dist/src/components/button/Button.stories.tsx +0 -156
  46. package/dist/src/components/button/Button.test.tsx +0 -152
  47. package/dist/src/components/button/Button.tsx +0 -81
  48. package/dist/src/components/button/ButtonGroup.test.tsx +0 -66
  49. package/dist/src/components/button/ButtonGroup.tsx +0 -46
  50. package/dist/src/components/button/ButtonRoot.test.tsx +0 -203
  51. package/dist/src/components/button/ButtonRoot.tsx +0 -190
  52. package/dist/src/components/button/IconButton.test.tsx +0 -103
  53. package/dist/src/components/button/IconButton.tsx +0 -80
  54. package/dist/src/components/button/__snapshots__/Button.test.tsx.snap +0 -96
  55. package/dist/src/components/button/__snapshots__/ButtonGroup.test.tsx.snap +0 -22
  56. package/dist/src/components/button/__snapshots__/ButtonRoot.test.tsx.snap +0 -160
  57. package/dist/src/components/button/__snapshots__/IconButton.test.tsx.snap +0 -83
  58. package/dist/src/components/button/index.ts +0 -4
  59. package/dist/src/components/checkbox/Checkbox.stories.tsx +0 -37
  60. package/dist/src/components/checkbox/Checkbox.test.tsx +0 -114
  61. package/dist/src/components/checkbox/Checkbox.tsx +0 -145
  62. package/dist/src/components/checkbox/__snapshots__/Checkbox.test.tsx.snap +0 -141
  63. package/dist/src/components/checkbox/index.ts +0 -1
  64. package/dist/src/components/chip/Chip.stories.tsx +0 -21
  65. package/dist/src/components/chip/Chip.test.tsx +0 -199
  66. package/dist/src/components/chip/Chip.tsx +0 -154
  67. package/dist/src/components/chip/ChipGroup.test.tsx +0 -29
  68. package/dist/src/components/chip/ChipGroup.tsx +0 -62
  69. package/dist/src/components/chip/__snapshots__/Chip.test.tsx.snap +0 -12
  70. package/dist/src/components/chip/__snapshots__/ChipGroup.test.tsx.snap +0 -29
  71. package/dist/src/components/chip/index.ts +0 -2
  72. package/dist/src/components/comment-block/CommentBlock.stories.tsx +0 -30
  73. package/dist/src/components/comment-block/CommentBlock.test.tsx +0 -28
  74. package/dist/src/components/comment-block/CommentBlock.tsx +0 -174
  75. package/dist/src/components/comment-block/__snapshots__/CommentBlock.test.tsx.snap +0 -92
  76. package/dist/src/components/comment-block/index.ts +0 -1
  77. package/dist/src/components/date-picker/DatePicker.test.tsx +0 -41
  78. package/dist/src/components/date-picker/DatePicker.tsx +0 -56
  79. package/dist/src/components/date-picker/DatePickerControlled.test.tsx +0 -44
  80. package/dist/src/components/date-picker/DatePickerControlled.tsx +0 -128
  81. package/dist/src/components/date-picker/DatePickerField.stories.tsx +0 -93
  82. package/dist/src/components/date-picker/DatePickerField.test.tsx +0 -47
  83. package/dist/src/components/date-picker/DatePickerField.tsx +0 -141
  84. package/dist/src/components/date-picker/__snapshots__/DatePicker.test.tsx.snap +0 -22
  85. package/dist/src/components/date-picker/__snapshots__/DatePickerControlled.test.tsx.snap +0 -597
  86. package/dist/src/components/date-picker/__snapshots__/DatePickerField.test.tsx.snap +0 -43
  87. package/dist/src/components/date-picker/constants.ts +0 -11
  88. package/dist/src/components/date-picker/index.ts +0 -4
  89. package/dist/src/components/date-picker/types.ts +0 -28
  90. package/dist/src/components/dialog/Dialog.stories.tsx +0 -426
  91. package/dist/src/components/dialog/Dialog.test.tsx +0 -93
  92. package/dist/src/components/dialog/Dialog.tsx +0 -263
  93. package/dist/src/components/dialog/__snapshots__/Dialog.test.tsx.snap +0 -960
  94. package/dist/src/components/dialog/index.ts +0 -1
  95. package/dist/src/components/divider/Divider.test.tsx +0 -93
  96. package/dist/src/components/divider/Divider.tsx +0 -51
  97. package/dist/src/components/divider/__snapshots__/Divider.test.tsx.snap +0 -9
  98. package/dist/src/components/divider/index.ts +0 -1
  99. package/dist/src/components/drag-handle/DragHandle.tsx +0 -50
  100. package/dist/src/components/drag-handle/index.ts +0 -1
  101. package/dist/src/components/dropdown/Dropdown.stories.tsx +0 -216
  102. package/dist/src/components/dropdown/Dropdown.test.tsx +0 -97
  103. package/dist/src/components/dropdown/Dropdown.tsx +0 -184
  104. package/dist/src/components/dropdown/__snapshots__/Dropdown.test.tsx.snap +0 -35
  105. package/dist/src/components/dropdown/index.ts +0 -1
  106. package/dist/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -116
  107. package/dist/src/components/expansion-panel/ExpansionPanel.tsx +0 -170
  108. package/dist/src/components/expansion-panel/index.ts +0 -1
  109. package/dist/src/components/flag/Flag.stories.tsx +0 -23
  110. package/dist/src/components/flag/Flag.test.tsx +0 -86
  111. package/dist/src/components/flag/Flag.tsx +0 -47
  112. package/dist/src/components/flag/__snapshots__/Flag.test.tsx.snap +0 -133
  113. package/dist/src/components/flag/index.ts +0 -1
  114. package/dist/src/components/flex-box/FlexBox.stories.tsx +0 -245
  115. package/dist/src/components/flex-box/FlexBox.test.tsx +0 -65
  116. package/dist/src/components/flex-box/FlexBox.tsx +0 -98
  117. package/dist/src/components/flex-box/__snapshots__/FlexBox.test.tsx.snap +0 -492
  118. package/dist/src/components/flex-box/index.ts +0 -1
  119. package/dist/src/components/generic-block/GenericBlock.stories.jsx +0 -128
  120. package/dist/src/components/generic-block/GenericBlock.test.tsx +0 -152
  121. package/dist/src/components/generic-block/GenericBlock.tsx +0 -222
  122. package/dist/src/components/generic-block/constants.ts +0 -9
  123. package/dist/src/components/generic-block/index.ts +0 -2
  124. package/dist/src/components/grid/Grid.tsx +0 -73
  125. package/dist/src/components/grid/GridItem.tsx +0 -54
  126. package/dist/src/components/grid/index.ts +0 -2
  127. package/dist/src/components/grid-column/GridColumn.stories.jsx +0 -56
  128. package/dist/src/components/grid-column/GridColumn.test.jsx +0 -58
  129. package/dist/src/components/grid-column/GridColumn.tsx +0 -90
  130. package/dist/src/components/grid-column/index.ts +0 -1
  131. package/dist/src/components/heading/Heading.stories.tsx +0 -108
  132. package/dist/src/components/heading/Heading.test.tsx +0 -82
  133. package/dist/src/components/heading/Heading.tsx +0 -63
  134. package/dist/src/components/heading/HeadingLevelProvider.tsx +0 -30
  135. package/dist/src/components/heading/constants.ts +0 -16
  136. package/dist/src/components/heading/context.tsx +0 -13
  137. package/dist/src/components/heading/index.ts +0 -3
  138. package/dist/src/components/heading/useHeadingLevel.tsx +0 -8
  139. package/dist/src/components/icon/Icon.stories.tsx +0 -76
  140. package/dist/src/components/icon/Icon.test.tsx +0 -102
  141. package/dist/src/components/icon/Icon.tsx +0 -121
  142. package/dist/src/components/icon/__snapshots__/Icon.test.tsx.snap +0 -49
  143. package/dist/src/components/icon/index.ts +0 -1
  144. package/dist/src/components/image-block/ImageBlock.stories.tsx +0 -52
  145. package/dist/src/components/image-block/ImageBlock.test.tsx +0 -28
  146. package/dist/src/components/image-block/ImageBlock.tsx +0 -151
  147. package/dist/src/components/image-block/__snapshots__/ImageBlock.test.tsx.snap +0 -64
  148. package/dist/src/components/image-block/index.ts +0 -1
  149. package/dist/src/components/index.ts +0 -176
  150. package/dist/src/components/inline-list/InlineList.stories.tsx +0 -40
  151. package/dist/src/components/inline-list/InlineList.test.tsx +0 -41
  152. package/dist/src/components/inline-list/InlineList.tsx +0 -82
  153. package/dist/src/components/inline-list/index.ts +0 -1
  154. package/dist/src/components/input-helper/InputHelper.stories.tsx +0 -29
  155. package/dist/src/components/input-helper/InputHelper.test.tsx +0 -107
  156. package/dist/src/components/input-helper/InputHelper.tsx +0 -61
  157. package/dist/src/components/input-helper/__snapshots__/InputHelper.test.tsx.snap +0 -9
  158. package/dist/src/components/input-helper/constants.ts +0 -11
  159. package/dist/src/components/input-helper/index.ts +0 -1
  160. package/dist/src/components/input-label/InputLabel.stories.tsx +0 -15
  161. package/dist/src/components/input-label/InputLabel.test.tsx +0 -86
  162. package/dist/src/components/input-label/InputLabel.tsx +0 -59
  163. package/dist/src/components/input-label/__snapshots__/InputLabel.test.tsx.snap +0 -10
  164. package/dist/src/components/input-label/index.ts +0 -1
  165. package/dist/src/components/lightbox/Lightbox.stories.tsx +0 -83
  166. package/dist/src/components/lightbox/Lightbox.test.tsx +0 -30
  167. package/dist/src/components/lightbox/Lightbox.tsx +0 -153
  168. package/dist/src/components/lightbox/__snapshots__/Lightbox.test.tsx.snap +0 -194
  169. package/dist/src/components/lightbox/index.ts +0 -1
  170. package/dist/src/components/link/Link.stories.tsx +0 -141
  171. package/dist/src/components/link/Link.test.tsx +0 -60
  172. package/dist/src/components/link/Link.tsx +0 -156
  173. package/dist/src/components/link/__snapshots__/Link.test.tsx.snap +0 -29
  174. package/dist/src/components/link/index.ts +0 -1
  175. package/dist/src/components/link-preview/LinkPreview.stories.tsx +0 -88
  176. package/dist/src/components/link-preview/LinkPreview.test.tsx +0 -102
  177. package/dist/src/components/link-preview/LinkPreview.tsx +0 -158
  178. package/dist/src/components/link-preview/index.ts +0 -1
  179. package/dist/src/components/list/List.stories.tsx +0 -141
  180. package/dist/src/components/list/List.test.tsx +0 -29
  181. package/dist/src/components/list/List.tsx +0 -94
  182. package/dist/src/components/list/ListDivider.stories.tsx +0 -7
  183. package/dist/src/components/list/ListDivider.test.tsx +0 -29
  184. package/dist/src/components/list/ListDivider.tsx +0 -42
  185. package/dist/src/components/list/ListItem.stories.tsx +0 -62
  186. package/dist/src/components/list/ListItem.test.tsx +0 -29
  187. package/dist/src/components/list/ListItem.tsx +0 -154
  188. package/dist/src/components/list/ListSubheader.stories.tsx +0 -8
  189. package/dist/src/components/list/ListSubheader.test.tsx +0 -29
  190. package/dist/src/components/list/ListSubheader.tsx +0 -43
  191. package/dist/src/components/list/__snapshots__/List.test.tsx.snap +0 -360
  192. package/dist/src/components/list/__snapshots__/ListDivider.test.tsx.snap +0 -7
  193. package/dist/src/components/list/__snapshots__/ListItem.test.tsx.snap +0 -160
  194. package/dist/src/components/list/__snapshots__/ListSubheader.test.tsx.snap +0 -9
  195. package/dist/src/components/list/index.ts +0 -4
  196. package/dist/src/components/list/useInteractiveList.tsx +0 -202
  197. package/dist/src/components/message/Message.stories.tsx +0 -27
  198. package/dist/src/components/message/Message.test.tsx +0 -76
  199. package/dist/src/components/message/Message.tsx +0 -74
  200. package/dist/src/components/message/__snapshots__/Message.test.tsx.snap +0 -15
  201. package/dist/src/components/message/index.ts +0 -1
  202. package/dist/src/components/mosaic/Mosaic.stories.tsx +0 -85
  203. package/dist/src/components/mosaic/Mosaic.test.tsx +0 -120
  204. package/dist/src/components/mosaic/Mosaic.tsx +0 -95
  205. package/dist/src/components/mosaic/__snapshots__/Mosaic.test.tsx.snap +0 -357
  206. package/dist/src/components/mosaic/index.ts +0 -1
  207. package/dist/src/components/notification/Notification.test.tsx +0 -108
  208. package/dist/src/components/notification/Notification.tsx +0 -130
  209. package/dist/src/components/notification/Notifications.stories.tsx +0 -77
  210. package/dist/src/components/notification/__snapshots__/Notification.test.tsx.snap +0 -34
  211. package/dist/src/components/notification/constants.ts +0 -28
  212. package/dist/src/components/notification/index.ts +0 -1
  213. package/dist/src/components/popover/Popover.stories.tsx +0 -386
  214. package/dist/src/components/popover/Popover.test.tsx +0 -30
  215. package/dist/src/components/popover/Popover.tsx +0 -382
  216. package/dist/src/components/popover/__snapshots__/Popover.test.tsx.snap +0 -343
  217. package/dist/src/components/popover/index.ts +0 -1
  218. package/dist/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -75
  219. package/dist/src/components/popover-dialog/PopoverDialog.test.tsx +0 -65
  220. package/dist/src/components/popover-dialog/PopoverDialog.tsx +0 -65
  221. package/dist/src/components/popover-dialog/index.tsx +0 -1
  222. package/dist/src/components/post-block/PostBlock.test.tsx +0 -28
  223. package/dist/src/components/post-block/PostBlock.tsx +0 -123
  224. package/dist/src/components/post-block/__snapshots__/PostBlock.test.tsx.snap +0 -139
  225. package/dist/src/components/post-block/index.ts +0 -1
  226. package/dist/src/components/progress/Progress.tsx +0 -68
  227. package/dist/src/components/progress/ProgressCircular.stories.tsx +0 -18
  228. package/dist/src/components/progress/ProgressCircular.test.tsx +0 -49
  229. package/dist/src/components/progress/ProgressCircular.tsx +0 -68
  230. package/dist/src/components/progress/ProgressLinear.stories.tsx +0 -8
  231. package/dist/src/components/progress/ProgressLinear.test.tsx +0 -37
  232. package/dist/src/components/progress/ProgressLinear.tsx +0 -52
  233. package/dist/src/components/progress/index.ts +0 -3
  234. package/dist/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
  235. package/dist/src/components/progress-tracker/ProgressTracker.test.tsx +0 -57
  236. package/dist/src/components/progress-tracker/ProgressTracker.tsx +0 -89
  237. package/dist/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -42
  238. package/dist/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -66
  239. package/dist/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -128
  240. package/dist/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
  241. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -73
  242. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -67
  243. package/dist/src/components/progress-tracker/__snapshots__/ProgressTracker.test.tsx.snap +0 -41
  244. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStep.test.tsx.snap +0 -141
  245. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStepPanel.test.tsx.snap +0 -25
  246. package/dist/src/components/progress-tracker/index.ts +0 -4
  247. package/dist/src/components/radio-button/RadioButton.stories.tsx +0 -28
  248. package/dist/src/components/radio-button/RadioButton.test.tsx +0 -123
  249. package/dist/src/components/radio-button/RadioButton.tsx +0 -141
  250. package/dist/src/components/radio-button/RadioGroup.stories.tsx +0 -42
  251. package/dist/src/components/radio-button/RadioGroup.test.tsx +0 -77
  252. package/dist/src/components/radio-button/RadioGroup.tsx +0 -52
  253. package/dist/src/components/radio-button/__snapshots__/RadioButton.test.tsx.snap +0 -113
  254. package/dist/src/components/radio-button/__snapshots__/RadioGroup.test.tsx.snap +0 -26
  255. package/dist/src/components/radio-button/index.ts +0 -2
  256. package/dist/src/components/select/Select.stories.tsx +0 -399
  257. package/dist/src/components/select/Select.test.tsx +0 -359
  258. package/dist/src/components/select/Select.tsx +0 -193
  259. package/dist/src/components/select/SelectMultiple.stories.tsx +0 -227
  260. package/dist/src/components/select/SelectMultiple.test.tsx +0 -405
  261. package/dist/src/components/select/SelectMultiple.tsx +0 -198
  262. package/dist/src/components/select/WithSelectContext.tsx +0 -143
  263. package/dist/src/components/select/__snapshots__/Select.test.tsx.snap +0 -43
  264. package/dist/src/components/select/__snapshots__/SelectMultiple.test.tsx.snap +0 -87
  265. package/dist/src/components/select/constants.ts +0 -53
  266. package/dist/src/components/select/index.ts +0 -2
  267. package/dist/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
  268. package/dist/src/components/side-navigation/SideNavigation.test.tsx +0 -52
  269. package/dist/src/components/side-navigation/SideNavigation.tsx +0 -54
  270. package/dist/src/components/side-navigation/SideNavigationItem.test.tsx +0 -175
  271. package/dist/src/components/side-navigation/SideNavigationItem.tsx +0 -162
  272. package/dist/src/components/side-navigation/__snapshots__/SideNavigation.test.tsx.snap +0 -7
  273. package/dist/src/components/side-navigation/__snapshots__/SideNavigationItem.test.tsx.snap +0 -30
  274. package/dist/src/components/side-navigation/index.ts +0 -2
  275. package/dist/src/components/skeleton/SkeletonCircle.stories.tsx +0 -25
  276. package/dist/src/components/skeleton/SkeletonCircle.test.tsx +0 -28
  277. package/dist/src/components/skeleton/SkeletonCircle.tsx +0 -52
  278. package/dist/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -107
  279. package/dist/src/components/skeleton/SkeletonRectangle.test.tsx +0 -28
  280. package/dist/src/components/skeleton/SkeletonRectangle.tsx +0 -78
  281. package/dist/src/components/skeleton/SkeletonTypography.stories.tsx +0 -26
  282. package/dist/src/components/skeleton/SkeletonTypography.test.tsx +0 -28
  283. package/dist/src/components/skeleton/SkeletonTypography.tsx +0 -57
  284. package/dist/src/components/skeleton/__snapshots__/SkeletonCircle.test.tsx.snap +0 -54
  285. package/dist/src/components/skeleton/__snapshots__/SkeletonRectangle.test.tsx.snap +0 -177
  286. package/dist/src/components/skeleton/__snapshots__/SkeletonTypography.test.tsx.snap +0 -174
  287. package/dist/src/components/skeleton/index.ts +0 -3
  288. package/dist/src/components/slider/Slider.stories.tsx +0 -29
  289. package/dist/src/components/slider/Slider.test.tsx +0 -31
  290. package/dist/src/components/slider/Slider.tsx +0 -299
  291. package/dist/src/components/slider/__snapshots__/Slider.test.tsx.snap +0 -122
  292. package/dist/src/components/slider/index.ts +0 -2
  293. package/dist/src/components/slideshow/Slides.tsx +0 -124
  294. package/dist/src/components/slideshow/Slideshow.stories.tsx +0 -212
  295. package/dist/src/components/slideshow/Slideshow.test.tsx +0 -39
  296. package/dist/src/components/slideshow/Slideshow.tsx +0 -170
  297. package/dist/src/components/slideshow/SlideshowControls.stories.tsx +0 -112
  298. package/dist/src/components/slideshow/SlideshowControls.tsx +0 -241
  299. package/dist/src/components/slideshow/SlideshowItem.tsx +0 -52
  300. package/dist/src/components/slideshow/SlideshowItemGroup.tsx +0 -64
  301. package/dist/src/components/slideshow/__snapshots__/Slideshow.test.tsx.snap +0 -157
  302. package/dist/src/components/slideshow/constants.ts +0 -24
  303. package/dist/src/components/slideshow/index.ts +0 -4
  304. package/dist/src/components/slideshow/useKeyNavigate.ts +0 -28
  305. package/dist/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
  306. package/dist/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
  307. package/dist/src/components/slideshow/useSwipeNavigate.ts +0 -18
  308. package/dist/src/components/switch/Switch.stories.tsx +0 -36
  309. package/dist/src/components/switch/Switch.test.tsx +0 -189
  310. package/dist/src/components/switch/Switch.tsx +0 -141
  311. package/dist/src/components/switch/__snapshots__/Switch.test.tsx.snap +0 -179
  312. package/dist/src/components/switch/index.ts +0 -1
  313. package/dist/src/components/table/Table.test.tsx +0 -28
  314. package/dist/src/components/table/Table.tsx +0 -59
  315. package/dist/src/components/table/TableBody.test.tsx +0 -22
  316. package/dist/src/components/table/TableBody.tsx +0 -44
  317. package/dist/src/components/table/TableCell.test.tsx +0 -23
  318. package/dist/src/components/table/TableCell.tsx +0 -125
  319. package/dist/src/components/table/TableHeader.test.tsx +0 -22
  320. package/dist/src/components/table/TableHeader.tsx +0 -50
  321. package/dist/src/components/table/TableRow.test.tsx +0 -22
  322. package/dist/src/components/table/TableRow.tsx +0 -68
  323. package/dist/src/components/table/__snapshots__/Table.test.tsx.snap +0 -263
  324. package/dist/src/components/table/index.ts +0 -5
  325. package/dist/src/components/tabs/Tab.test.tsx +0 -116
  326. package/dist/src/components/tabs/Tab.tsx +0 -120
  327. package/dist/src/components/tabs/TabList.test.tsx +0 -80
  328. package/dist/src/components/tabs/TabList.tsx +0 -82
  329. package/dist/src/components/tabs/TabPanel.test.tsx +0 -74
  330. package/dist/src/components/tabs/TabPanel.tsx +0 -65
  331. package/dist/src/components/tabs/TabProvider.test.tsx +0 -42
  332. package/dist/src/components/tabs/TabProvider.tsx +0 -59
  333. package/dist/src/components/tabs/Tabs.stories.tsx +0 -134
  334. package/dist/src/components/tabs/__snapshots__/Tab.test.tsx.snap +0 -62
  335. package/dist/src/components/tabs/__snapshots__/TabList.test.tsx.snap +0 -22
  336. package/dist/src/components/tabs/__snapshots__/TabPanel.test.tsx.snap +0 -25
  337. package/dist/src/components/tabs/index.ts +0 -4
  338. package/dist/src/components/tabs/state.ts +0 -116
  339. package/dist/src/components/tabs/test.mocks.ts +0 -33
  340. package/dist/src/components/text/Text.stories.jsx +0 -75
  341. package/dist/src/components/text/Text.test.tsx +0 -108
  342. package/dist/src/components/text/Text.tsx +0 -121
  343. package/dist/src/components/text/index.ts +0 -1
  344. package/dist/src/components/text-field/TextField.stories.tsx +0 -169
  345. package/dist/src/components/text-field/TextField.test.tsx +0 -171
  346. package/dist/src/components/text-field/TextField.tsx +0 -432
  347. package/dist/src/components/text-field/__snapshots__/TextField.test.tsx.snap +0 -42
  348. package/dist/src/components/text-field/index.ts +0 -1
  349. package/dist/src/components/thumbnail/Thumbnail.stories.tsx +0 -510
  350. package/dist/src/components/thumbnail/Thumbnail.test.tsx +0 -46
  351. package/dist/src/components/thumbnail/Thumbnail.tsx +0 -222
  352. package/dist/src/components/thumbnail/__snapshots__/Thumbnail.test.tsx.snap +0 -130
  353. package/dist/src/components/thumbnail/index.ts +0 -3
  354. package/dist/src/components/thumbnail/types.ts +0 -39
  355. package/dist/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
  356. package/dist/src/components/thumbnail/useFocusPointStyle.tsx +0 -111
  357. package/dist/src/components/thumbnail/useImageLoad.ts +0 -40
  358. package/dist/src/components/toolbar/Toolbar.tsx +0 -67
  359. package/dist/src/components/toolbar/index.ts +0 -1
  360. package/dist/src/components/tooltip/Tooltip.stories.tsx +0 -172
  361. package/dist/src/components/tooltip/Tooltip.test.tsx +0 -105
  362. package/dist/src/components/tooltip/Tooltip.tsx +0 -122
  363. package/dist/src/components/tooltip/__snapshots__/Tooltip.test.tsx.snap +0 -233
  364. package/dist/src/components/tooltip/index.ts +0 -1
  365. package/dist/src/components/tooltip/useInjectTooltipRef.tsx +0 -44
  366. package/dist/src/components/tooltip/useTooltipOpen.tsx +0 -113
  367. package/dist/src/components/uploader/Uploader.test.tsx +0 -87
  368. package/dist/src/components/uploader/Uploader.tsx +0 -105
  369. package/dist/src/components/uploader/__snapshots__/Uploader.test.tsx.snap +0 -14
  370. package/dist/src/components/uploader/index.ts +0 -1
  371. package/dist/src/components/user-block/UserBlock.stories.tsx +0 -76
  372. package/dist/src/components/user-block/UserBlock.test.tsx +0 -38
  373. package/dist/src/components/user-block/UserBlock.tsx +0 -179
  374. package/dist/src/components/user-block/__snapshots__/UserBlock.test.tsx.snap +0 -362
  375. package/dist/src/components/user-block/index.ts +0 -1
  376. package/dist/src/constants.ts +0 -17
  377. package/dist/src/hooks/useBooleanState.tsx +0 -13
  378. package/dist/src/hooks/useCallbackOnEscape.ts +0 -34
  379. package/dist/src/hooks/useChipGroupNavigation.tsx +0 -75
  380. package/dist/src/hooks/useClickAway.tsx +0 -47
  381. package/dist/src/hooks/useDisableBodyScroll.ts +0 -28
  382. package/dist/src/hooks/useEventCallback.tsx +0 -17
  383. package/dist/src/hooks/useFocus.tsx +0 -21
  384. package/dist/src/hooks/useFocusTrap.ts +0 -85
  385. package/dist/src/hooks/useFocusWithin.ts +0 -33
  386. package/dist/src/hooks/useInfiniteScroll.tsx +0 -60
  387. package/dist/src/hooks/useIntersectionObserver.tsx +0 -43
  388. package/dist/src/hooks/useInterval.tsx +0 -31
  389. package/dist/src/hooks/useKeyboardListNavigation.tsx +0 -204
  390. package/dist/src/hooks/useListenFocus.tsx +0 -26
  391. package/dist/src/hooks/useOnResize.ts +0 -41
  392. package/dist/src/hooks/useRovingTabIndex.tsx +0 -90
  393. package/dist/src/hooks/useSlideshowControls.ts +0 -243
  394. package/dist/src/hooks/useStopPropagation.ts +0 -21
  395. package/dist/src/hooks/useTransitionVisibility.ts +0 -54
  396. package/dist/src/index.ts +0 -58
  397. package/dist/src/stories/chromaticForceScreenSize.tsx +0 -7
  398. package/dist/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
  399. package/dist/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
  400. package/dist/src/stories/generated/Badge/Demos.stories.tsx +0 -9
  401. package/dist/src/stories/generated/Button/Demos.stories.tsx +0 -11
  402. package/dist/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
  403. package/dist/src/stories/generated/Chip/Demos.stories.tsx +0 -11
  404. package/dist/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
  405. package/dist/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
  406. package/dist/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
  407. package/dist/src/stories/generated/Divider/Demos.stories.tsx +0 -6
  408. package/dist/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
  409. package/dist/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
  410. package/dist/src/stories/generated/Flag/Demos.stories.tsx +0 -6
  411. package/dist/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
  412. package/dist/src/stories/generated/Heading/Demos.stories.tsx +0 -6
  413. package/dist/src/stories/generated/Icon/Demos.stories.tsx +0 -8
  414. package/dist/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
  415. package/dist/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
  416. package/dist/src/stories/generated/Link/Demos.stories.tsx +0 -8
  417. package/dist/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
  418. package/dist/src/stories/generated/List/Demos.stories.tsx +0 -11
  419. package/dist/src/stories/generated/Message/Demos.stories.tsx +0 -10
  420. package/dist/src/stories/generated/Mosaic/Demos.stories.tsx +0 -9
  421. package/dist/src/stories/generated/Notification/Demos.stories.tsx +0 -6
  422. package/dist/src/stories/generated/Popover/Demos.stories.tsx +0 -11
  423. package/dist/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
  424. package/dist/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
  425. package/dist/src/stories/generated/Progress/Demos.stories.tsx +0 -7
  426. package/dist/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
  427. package/dist/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
  428. package/dist/src/stories/generated/Select/Demos.stories.tsx +0 -14
  429. package/dist/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
  430. package/dist/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
  431. package/dist/src/stories/generated/Slider/Demos.stories.tsx +0 -9
  432. package/dist/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
  433. package/dist/src/stories/generated/Switch/Demos.stories.tsx +0 -6
  434. package/dist/src/stories/generated/Table/Demos.stories.tsx +0 -6
  435. package/dist/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
  436. package/dist/src/stories/generated/TextField/Demos.stories.tsx +0 -19
  437. package/dist/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
  438. package/dist/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
  439. package/dist/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
  440. package/dist/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
  441. package/dist/src/stories/generated/UserBlock/Demos.stories.tsx +0 -10
  442. package/dist/src/stories/knobs/buttonKnob.ts +0 -9
  443. package/dist/src/stories/knobs/emphasisKnob.ts +0 -8
  444. package/dist/src/stories/knobs/enumKnob.ts +0 -14
  445. package/dist/src/stories/knobs/focusKnob.ts +0 -3
  446. package/dist/src/stories/knobs/image.ts +0 -69
  447. package/dist/src/stories/knobs/lorem.ts +0 -59
  448. package/dist/src/stories/knobs/sizeKnob.ts +0 -5
  449. package/dist/src/stories/knobs/thumbnailsKnob.ts +0 -9
  450. package/dist/src/stories/utils/CustomLink.tsx +0 -7
  451. package/dist/src/stories/withResizableBox.tsx +0 -18
  452. package/dist/src/testing/utils/commonTestsSuite.ts +0 -71
  453. package/dist/src/testing/utils/commonTestsSuiteRTL.ts +0 -55
  454. package/dist/src/testing/utils/index.ts +0 -4
  455. package/dist/src/testing/utils/itShouldRenderStories.tsx +0 -103
  456. package/dist/src/testing/utils/queries.ts +0 -19
  457. package/dist/src/untypped-modules.d.ts +0 -7
  458. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -58
  459. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -65
  460. package/dist/src/utils/ClickAwayProvider/index.ts +0 -1
  461. package/dist/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
  462. package/dist/src/utils/MaterialThemeSwitcher/index.ts +0 -1
  463. package/dist/src/utils/browserDoesNotSupportHover.test.js +0 -24
  464. package/dist/src/utils/browserDoesNotSupportHover.ts +0 -2
  465. package/dist/src/utils/clamp.ts +0 -17
  466. package/dist/src/utils/className.ts +0 -44
  467. package/dist/src/utils/event.ts +0 -1
  468. package/dist/src/utils/flattenChildren.test.tsx +0 -58
  469. package/dist/src/utils/flattenChildren.ts +0 -27
  470. package/dist/src/utils/focus/constants.ts +0 -5
  471. package/dist/src/utils/focus/getFirstAndLastFocusable.test.ts +0 -134
  472. package/dist/src/utils/focus/getFirstAndLastFocusable.ts +0 -21
  473. package/dist/src/utils/focus/getFocusableElements.test.ts +0 -151
  474. package/dist/src/utils/focus/getFocusableElements.ts +0 -7
  475. package/dist/src/utils/index.ts +0 -5
  476. package/dist/src/utils/isInternetExplorer.ts +0 -15
  477. package/dist/src/utils/makeListenerTowerContext.ts +0 -32
  478. package/dist/src/utils/mergeRefs.ts +0 -22
  479. package/dist/src/utils/partitionMulti.ts +0 -28
  480. package/dist/src/utils/renderLink.tsx +0 -17
  481. package/dist/src/utils/type.ts +0 -113
  482. package/dist/src/utils/userHasReducedMotion.ts +0 -7
  483. package/dist/src/utils/utils.test.ts +0 -48
  484. package/jest/__mocks__/@storybook/addon-actions.js +0 -3
  485. package/jest/__mocks__/@storybook/addon-knobs.js +0 -6
  486. package/jest/__mocks__/emptyFileMockTransformer.js +0 -8
  487. package/jest/__mocks__/emptyModuleMock.js +0 -1
  488. package/jest/configure.js +0 -6
  489. package/jest/index.js +0 -36
  490. package/jest/transform.js +0 -6
  491. package/rollup.config.js +0 -98
  492. package/storybook/build +0 -4
  493. package/storybook/generate-demo-stories.js +0 -59
  494. package/storybook/main.js +0 -67
  495. package/storybook/package.json +0 -13
  496. package/storybook/preview.js +0 -11
  497. package/storybook/start +0 -4
  498. package/storybook/story-block/StoryBlock.tsx +0 -49
  499. package/storybook/story-block/decorator.jsx +0 -7
  500. package/storybook/story-block/index.scss +0 -27
  501. package/storybook/yarn.lock +0 -13192
  502. package/tsconfig.json +0 -3
@@ -1,184 +0,0 @@
1
- import React, { cloneElement, forwardRef, useMemo, useRef } from 'react';
2
-
3
- import classNames from 'classnames';
4
-
5
- import { List, ListProps } from '@lumx/react/components/list/List';
6
- import { Offset, Placement, Popover, PopoverProps } from '@lumx/react/components/popover/Popover';
7
- import { useInfiniteScroll } from '@lumx/react/hooks/useInfiniteScroll';
8
- import { Comp, GenericProps, isComponent } from '@lumx/react/utils/type';
9
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
10
-
11
- /**
12
- * Defines the props of the component.
13
- */
14
- export interface DropdownProps extends GenericProps {
15
- /**
16
- * Reference to the element around which the dropdown is placed.
17
- * @see {@link PopoverProps#anchorRef}
18
- */
19
- anchorRef: PopoverProps['anchorRef'];
20
- /** Dropdown content. */
21
- children: React.ReactNode;
22
- /**
23
- * Whether a click anywhere out of the Dropdown would close it or not.
24
- * @see {@link PopoverProps#closeOnClickAway}
25
- */
26
- closeOnClickAway?: boolean;
27
- /**
28
- * Whether to close the Dropdown when clicking in it or not.
29
- */
30
- closeOnClick?: boolean;
31
- /**
32
- * Whether an escape key press would close the Dropdown or not.
33
- * @see {@link PopoverProps#closeOnEscape}
34
- */
35
- closeOnEscape?: boolean;
36
- /**
37
- * Manage dropdown width:
38
- * - `maxWidth`: dropdown not bigger than anchor
39
- * - `minWidth` or `true`: dropdown not smaller than anchor
40
- * - `width`: dropdown equal to the anchor.
41
- * @see {@link PopoverProps#fitToAnchorWidth}
42
- */
43
- fitToAnchorWidth?: PopoverProps['fitToAnchorWidth'];
44
- /**
45
- * Whether the dropdown should shrink to fit within the viewport height or not.
46
- * @see {@link PopoverProps#fitWithinViewportHeight}
47
- */
48
- fitWithinViewportHeight?: boolean;
49
- /**
50
- * Whether the dropdown should be displayed or not. Useful to control the Dropdown from outside the component.
51
- * @see {@link PopoverProps#isOpen}
52
- */
53
- isOpen: boolean;
54
- /**
55
- * Offset applied to the Dropdown position.
56
- * @see {@link PopoverProps#offset}
57
- */
58
- offset?: Offset;
59
- /**
60
- * Preferred Dropdown placement against the anchor element.
61
- * @see {@link PopoverProps#placement}
62
- */
63
- placement?: Placement;
64
- /** Whether the focus should be set on the list when the dropdown is open or not. */
65
- shouldFocusOnOpen?: boolean;
66
- /** Whether the dropdown should be rendered into a DOM node that exists outside the DOM hierarchy of the parent component. */
67
- usePortal?: boolean;
68
- /** Whether the focus should go back on the anchor when dropdown closes and focus is within. */
69
- focusAnchorOnClose?: boolean;
70
- /**
71
- * Z-axis position.
72
- * @see {@link PopoverProps#zIndex}
73
- */
74
- zIndex?: number;
75
- /**
76
- * On close callback.
77
- * @see {@link PopoverProps#onClose}
78
- */
79
- onClose?(): void;
80
- /** On scroll end callback. */
81
- onInfiniteScroll?(): void;
82
- }
83
-
84
- /**
85
- * Component display name.
86
- */
87
- const COMPONENT_NAME = 'Dropdown';
88
-
89
- /**
90
- * Component default class name and class prefix.
91
- */
92
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
93
-
94
- /**
95
- * Component default props.
96
- */
97
- const DEFAULT_PROPS: Partial<DropdownProps> = {
98
- closeOnClick: true,
99
- closeOnClickAway: true,
100
- closeOnEscape: true,
101
- fitToAnchorWidth: true,
102
- fitWithinViewportHeight: true,
103
- placement: Placement.BOTTOM_START,
104
- shouldFocusOnOpen: true,
105
- focusAnchorOnClose: true,
106
- };
107
-
108
- /**
109
- * Dropdown component.
110
- *
111
- * @param props Component props.
112
- * @param ref Component ref.
113
- * @return React element.
114
- */
115
- export const Dropdown: Comp<DropdownProps, HTMLDivElement> = forwardRef((props, ref) => {
116
- const {
117
- anchorRef,
118
- children,
119
- className,
120
- closeOnClick,
121
- closeOnClickAway,
122
- closeOnEscape,
123
- fitToAnchorWidth,
124
- fitWithinViewportHeight,
125
- isOpen,
126
- offset,
127
- focusAnchorOnClose,
128
- onClose,
129
- onInfiniteScroll,
130
- placement,
131
- shouldFocusOnOpen,
132
- zIndex,
133
- ...forwardedProps
134
- } = props;
135
- const innerRef = useRef<HTMLDivElement>(null);
136
- const listElement = useRef(null);
137
-
138
- useInfiniteScroll(innerRef, onInfiniteScroll);
139
-
140
- const popperElement = useMemo(() => {
141
- return !Array.isArray(children) && isComponent(List)(children)
142
- ? cloneElement<ListProps>(children, {
143
- ...children.props,
144
- ref: listElement,
145
- onClick(evt: MouseEvent) {
146
- children.props.onClick?.(evt);
147
-
148
- if (closeOnClick) {
149
- onClose?.();
150
- }
151
- },
152
- isClickable: true,
153
- })
154
- : children;
155
- }, [children, closeOnClick, onClose]);
156
-
157
- return isOpen ? (
158
- <Popover
159
- ref={ref}
160
- {...forwardedProps}
161
- focusAnchorOnClose={focusAnchorOnClose}
162
- anchorRef={anchorRef}
163
- className={classNames(className, handleBasicClasses({ prefix: CLASSNAME }))}
164
- elevation={0 as any}
165
- closeOnClickAway={closeOnClickAway}
166
- closeOnEscape={closeOnEscape}
167
- fitToAnchorWidth={fitToAnchorWidth}
168
- fitWithinViewportHeight={fitWithinViewportHeight}
169
- focusElement={shouldFocusOnOpen ? listElement : undefined}
170
- isOpen={isOpen}
171
- offset={offset}
172
- onClose={onClose}
173
- placement={placement}
174
- zIndex={zIndex}
175
- >
176
- <div className={`${CLASSNAME}__menu`} ref={innerRef}>
177
- {popperElement}
178
- </div>
179
- </Popover>
180
- ) : null;
181
- });
182
- Dropdown.displayName = COMPONENT_NAME;
183
- Dropdown.className = CLASSNAME;
184
- Dropdown.defaultProps = DEFAULT_PROPS;
@@ -1,35 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`<Dropdown> Snapshots and structure should render correctly 1`] = `
4
- <Popover
5
- anchorRef={
6
- {
7
- "current": null,
8
- }
9
- }
10
- className="lumx-dropdown"
11
- closeOnClickAway={true}
12
- closeOnEscape={true}
13
- elevation={0}
14
- fitToAnchorWidth={true}
15
- fitWithinViewportHeight={true}
16
- focusAnchorOnClose={true}
17
- focusElement={
18
- {
19
- "current": null,
20
- }
21
- }
22
- isOpen={true}
23
- placement="bottom-start"
24
- usePortal={true}
25
- zIndex={9999}
26
- >
27
- <div
28
- className="lumx-dropdown__menu"
29
- >
30
- <div>
31
- This is the content of the dropdown
32
- </div>
33
- </div>
34
- </Popover>
35
- `;
@@ -1 +0,0 @@
1
- export * from './Dropdown';
@@ -1,116 +0,0 @@
1
- import React from 'react';
2
-
3
- import { commonTestsSuiteRTL } from '@lumx/react/testing/utils';
4
- import { queryByRole, render } from '@testing-library/react';
5
- import { getByClassName, queryByClassName } from '@lumx/react/testing/utils/queries';
6
- import userEvent from '@testing-library/user-event';
7
- import { ExpansionPanel, ExpansionPanelProps } from '.';
8
-
9
- const CLASSNAME = ExpansionPanel.className as string;
10
-
11
- type SetupProps = Partial<ExpansionPanelProps>;
12
-
13
- /**
14
- * Mounts the component and returns common DOM elements / data needed in multiple tests further down.
15
- */
16
- const setup = (propsOverride: SetupProps = {}) => {
17
- const props: ExpansionPanelProps = {
18
- toggleButtonProps: { label: 'Toggle' },
19
- ...propsOverride,
20
- };
21
- const { container } = render(<ExpansionPanel {...props} />);
22
-
23
- return {
24
- container,
25
- element: getByClassName(container, CLASSNAME),
26
- query: {
27
- toggleButton: () => queryByRole(container, 'button', { name: /Toggle/i }),
28
- header: () => queryByClassName(container, `${CLASSNAME}__header`),
29
- content: () => queryByClassName(container, `${CLASSNAME}__wrapper`),
30
- },
31
- props,
32
- };
33
- };
34
-
35
- describe(`<${ExpansionPanel.displayName}>`, () => {
36
- describe('Render', () => {
37
- it('should render default', () => {
38
- const { element, query } = setup();
39
- expect(element).toBeInTheDocument();
40
- expect(element).toHaveClass(CLASSNAME);
41
- expect(element).toHaveClass(`${CLASSNAME}--is-close`);
42
- expect(element).toHaveClass(`${CLASSNAME}--theme-light`);
43
-
44
- // Header is visible
45
- expect(query.header()).toBeInTheDocument();
46
-
47
- // Content is not visible
48
- expect(query.content()).not.toBeInTheDocument();
49
-
50
- expect(query.toggleButton()).toHaveAttribute('aria-expanded', 'false');
51
- });
52
-
53
- it('should render open', () => {
54
- const { query } = setup({ isOpen: true });
55
-
56
- // Content is visible
57
- expect(query.content()).toBeInTheDocument();
58
-
59
- expect(query.toggleButton()).toHaveAttribute('aria-expanded', 'true');
60
- });
61
-
62
- it('should show label', () => {
63
- const labelText = 'Label text';
64
- const { query } = setup({ label: labelText });
65
-
66
- expect(query.header()).toHaveTextContent(labelText);
67
- });
68
-
69
- it('should show header instead of label', () => {
70
- const labelText = 'Label text';
71
- const headerText = 'Header text';
72
- const { query } = setup({ label: labelText, children: <header>{headerText}</header> });
73
-
74
- expect(query.header()).toHaveTextContent(headerText);
75
- });
76
- });
77
-
78
- describe('Events', () => {
79
- const onOpen: jest.Mock = jest.fn();
80
- const onClose: jest.Mock = jest.fn();
81
- const onToggleOpen: jest.Mock = jest.fn();
82
-
83
- beforeEach(onOpen.mockClear);
84
- beforeEach(onClose.mockClear);
85
- beforeEach(onToggleOpen.mockClear);
86
-
87
- it('should open on click', async () => {
88
- const { query } = setup({ isOpen: false, onOpen, onClose, onToggleOpen });
89
-
90
- // Content is not visible
91
- expect(query.content()).not.toBeInTheDocument();
92
-
93
- // Click on toggle button
94
- await userEvent.click(query.toggleButton() as any);
95
- expect(onOpen).toHaveBeenCalled();
96
- expect(onClose).not.toHaveBeenCalled();
97
- expect(onToggleOpen).toHaveBeenCalledWith(true);
98
- });
99
-
100
- it('should close on click', async () => {
101
- const { query } = setup({ isOpen: true, onOpen, onClose, onToggleOpen });
102
-
103
- // Content is visible
104
- expect(query.content()).toBeInTheDocument();
105
-
106
- // Click on header
107
- await userEvent.click(query.header() as any);
108
- expect(onOpen).not.toHaveBeenCalled();
109
- expect(onClose).toHaveBeenCalled();
110
- expect(onToggleOpen).toHaveBeenCalledWith(false);
111
- });
112
- });
113
-
114
- // Common tests suite.
115
- commonTestsSuiteRTL(setup, { baseClassName: CLASSNAME, forwardClassName: 'element', forwardAttributes: 'element' });
116
- });
@@ -1,170 +0,0 @@
1
- import React, { Children, forwardRef, PropsWithChildren, ReactNode, useEffect, useRef, useState } from 'react';
2
-
3
- import classNames from 'classnames';
4
-
5
- import { mdiChevronDown, mdiChevronUp } from '@lumx/icons';
6
-
7
- import get from 'lodash/get';
8
- import isEmpty from 'lodash/isEmpty';
9
- import isFunction from 'lodash/isFunction';
10
-
11
- import { ColorPalette, DragHandle, Emphasis, IconButton, IconButtonProps, Theme } from '@lumx/react';
12
- import { Callback, Comp, GenericProps, HasTheme, isComponent } from '@lumx/react/utils/type';
13
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
14
- import { partitionMulti } from '@lumx/react/utils/partitionMulti';
15
-
16
- /**
17
- * Defines the props of the component.
18
- */
19
- export interface ExpansionPanelProps extends GenericProps, HasTheme {
20
- /** Whether the expansion panel has a background. */
21
- hasBackground?: boolean;
22
- /** Whether the header has a divider. */
23
- hasHeaderDivider?: boolean;
24
- /** Whether the component is open or not. */
25
- isOpen?: boolean;
26
- /** Label text (overwritten if a `<header>` is provided in the children). */
27
- label?: string;
28
- /** On open callback. */
29
- onOpen?: Callback;
30
- /** On close callback. */
31
- onClose?: Callback;
32
- /** Props to pass to the toggle button (minus those already set by the ExpansionPanel props). */
33
- toggleButtonProps: Pick<IconButtonProps, 'label'> &
34
- Omit<IconButtonProps, 'label' | 'onClick' | 'icon' | 'emphasis' | 'color'>;
35
- /** On toggle open or close callback. */
36
- onToggleOpen?(shouldOpen: boolean): void;
37
- }
38
-
39
- /**
40
- * Component display name.
41
- */
42
- const COMPONENT_NAME = 'ExpansionPanel';
43
-
44
- /**
45
- * Component default class name and class prefix.
46
- */
47
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
48
-
49
- /**
50
- * Component default props.
51
- */
52
- const DEFAULT_PROPS: Partial<ExpansionPanelProps> = {
53
- theme: Theme.light,
54
- };
55
-
56
- const isDragHandle = isComponent(DragHandle);
57
- const isHeader = isComponent('header');
58
- const isFooter = isComponent('footer');
59
-
60
- /**
61
- * ExpansionPanel component.
62
- *
63
- * @param props Component props.
64
- * @param ref Component ref.
65
- * @return React element.
66
- */
67
- export const ExpansionPanel: Comp<ExpansionPanelProps, HTMLDivElement> = forwardRef((props, ref) => {
68
- const {
69
- className,
70
- children: anyChildren,
71
- hasBackground,
72
- hasHeaderDivider,
73
- isOpen,
74
- label,
75
- onClose,
76
- onOpen,
77
- onToggleOpen,
78
- theme,
79
- toggleButtonProps,
80
- ...forwardedProps
81
- } = props;
82
-
83
- const children: ReactNode[] = Children.toArray(anyChildren);
84
-
85
- // Partition children by types.
86
- const [[dragHandle], [header], [footer], content] = partitionMulti(children, [isDragHandle, isHeader, isFooter]);
87
-
88
- // Either take the header in children or create one with the label.
89
- const headerProps: PropsWithChildren<any> = React.isValidElement(header) ? header.props : {};
90
- const headerContent = !isEmpty(headerProps.children) ? (
91
- headerProps.children
92
- ) : (
93
- <span className={`${CLASSNAME}__label`}>{label}</span>
94
- );
95
-
96
- const toggleOpen = () => {
97
- const shouldOpen = !isOpen;
98
- if (isFunction(onOpen) && shouldOpen) {
99
- onOpen();
100
- }
101
- if (isFunction(onClose) && !shouldOpen) {
102
- onClose();
103
- }
104
- if (isFunction(onToggleOpen)) {
105
- onToggleOpen(shouldOpen);
106
- }
107
- };
108
-
109
- const color = theme === Theme.dark ? ColorPalette.light : ColorPalette.dark;
110
-
111
- const rootClassName = classNames(
112
- className,
113
- handleBasicClasses({
114
- hasBackground,
115
- hasHeader: Boolean(!isEmpty(headerProps.children)),
116
- hasHeaderDivider,
117
- isClose: !isOpen,
118
- isDraggable: Boolean(dragHandle),
119
- isOpen,
120
- prefix: CLASSNAME,
121
- theme,
122
- }),
123
- );
124
-
125
- const wrapperRef = useRef<HTMLDivElement>(null);
126
- const isContentVisible = (): boolean => get(wrapperRef.current, 'clientHeight', 0) > 0;
127
-
128
- // Switch max height on/off to activate the CSS transition (updates when children changes).
129
- const [maxHeight, setMaxHeight] = useState('0');
130
- useEffect(() => {
131
- const height = isOpen ? get(wrapperRef.current, 'offsetHeight', 0) : 0;
132
- setMaxHeight(`${height}px`);
133
- }, [children, isOpen]);
134
-
135
- return (
136
- <section ref={ref} {...forwardedProps} className={rootClassName}>
137
- {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events,jsx-a11y/no-static-element-interactions */}
138
- <header className={`${CLASSNAME}__header`} onClick={toggleOpen}>
139
- {dragHandle && <div className={`${CLASSNAME}__header-drag`}>{dragHandle}</div>}
140
-
141
- <div {...headerProps} className={`${CLASSNAME}__header-content`}>
142
- {headerContent}
143
- </div>
144
-
145
- <div className={`${CLASSNAME}__header-toggle`}>
146
- <IconButton
147
- {...toggleButtonProps}
148
- color={color}
149
- emphasis={Emphasis.low}
150
- icon={isOpen ? mdiChevronUp : mdiChevronDown}
151
- aria-expanded={isOpen || 'false'}
152
- />
153
- </div>
154
- </header>
155
-
156
- {(isOpen || isContentVisible()) && (
157
- <div className={`${CLASSNAME}__wrapper`} style={{ maxHeight }}>
158
- <div className={`${CLASSNAME}__container`} ref={wrapperRef}>
159
- <div className={`${CLASSNAME}__content`}>{content}</div>
160
-
161
- {footer && <div className={`${CLASSNAME}__footer`}>{footer}</div>}
162
- </div>
163
- </div>
164
- )}
165
- </section>
166
- );
167
- });
168
- ExpansionPanel.displayName = COMPONENT_NAME;
169
- ExpansionPanel.className = CLASSNAME;
170
- ExpansionPanel.defaultProps = DEFAULT_PROPS;
@@ -1 +0,0 @@
1
- export * from './ExpansionPanel';
@@ -1,23 +0,0 @@
1
- import React from 'react';
2
- import { text } from '@storybook/addon-knobs';
3
-
4
- import { mdiHeart } from '@lumx/icons';
5
- import { ColorPalette, Flag } from '@lumx/react';
6
-
7
- export default { title: 'LumX components/flag/Flag' };
8
-
9
- export const defaultProps = ({ theme }: any) => <Flag label={text('Label', 'hearing')} theme={theme} />;
10
- export const withIcon = ({ theme }: any) => <Flag icon={mdiHeart} label={text('Label', 'hearing')} theme={theme} />;
11
- export const withColor = ({ theme }: any) => {
12
- return (
13
- <>
14
- <Flag color={ColorPalette.blue} icon={mdiHeart} label="blue" theme={theme} />
15
- <Flag color={ColorPalette.dark} icon={mdiHeart} label="dark" theme={theme} />
16
- <Flag color={ColorPalette.green} icon={mdiHeart} label="green" theme={theme} />
17
- <Flag color={ColorPalette.primary} icon={mdiHeart} label="primary" theme={theme} />
18
- <Flag color={ColorPalette.red} icon={mdiHeart} label="red" theme={theme} />
19
- <Flag color={ColorPalette.secondary} icon={mdiHeart} label="secondary" theme={theme} />
20
- <Flag color={ColorPalette.yellow} icon={mdiHeart} label="yellow" theme={theme} />
21
- </>
22
- );
23
- };
@@ -1,86 +0,0 @@
1
- import { mount, shallow } from 'enzyme';
2
- import 'jest-enzyme';
3
- import React, { ReactElement } from 'react';
4
-
5
- import { ColorPalette, Theme } from '@lumx/react';
6
- import { mdiAbTesting } from '@lumx/icons';
7
- import { itShouldRenderStories, commonTestsSuite, Wrapper } from '@lumx/react/testing/utils';
8
- import { getBasicClass } from '@lumx/react/utils/className';
9
-
10
- import { Flag, FlagProps } from './Flag';
11
- import * as stories from './Flag.stories';
12
-
13
- const CLASSNAME = Flag.className as string;
14
-
15
- /**
16
- * Mounts the component and returns common DOM elements / data needed in multiple tests further down.
17
- */
18
- const setup = (propOverrides: Partial<FlagProps> = {}, shallowRendering = true) => {
19
- const props = {
20
- label: 'default',
21
- ...propOverrides,
22
- };
23
- const renderer: (el: ReactElement) => Wrapper = shallowRendering ? shallow : mount;
24
- const wrapper = renderer(<Flag {...props} />);
25
-
26
- return {
27
- props,
28
- iconEl: wrapper.find('Icon'),
29
- wrapper,
30
- };
31
- };
32
-
33
- describe(`<${Flag.displayName} />`, () => {
34
- // 1. Test render via snapshot (default state of component).
35
- describe('Snapshots and structure', () => {
36
- itShouldRenderStories(stories, Flag);
37
- });
38
-
39
- // 4. Test conditions (i.e. things that display or not in the UI based on props).
40
- describe('Conditions', () => {
41
- it('should use the icon', () => {
42
- const { iconEl } = setup({ icon: mdiAbTesting });
43
-
44
- expect(iconEl).toBeDefined();
45
- expect(iconEl.prop('icon')).toEqual(mdiAbTesting);
46
- });
47
-
48
- it('should have correct default color', () => {
49
- const { wrapper } = setup({});
50
- expect(wrapper).toHaveClassName(
51
- getBasicClass({
52
- prefix: CLASSNAME,
53
- type: 'color',
54
- value: ColorPalette.dark,
55
- }),
56
- );
57
- });
58
-
59
- it('should switch color with theme', () => {
60
- const { wrapper } = setup({ theme: Theme.dark });
61
- expect(wrapper).toHaveClassName(
62
- getBasicClass({
63
- prefix: CLASSNAME,
64
- type: 'color',
65
- value: ColorPalette.light,
66
- }),
67
- );
68
- });
69
-
70
- it('should use the color', () => {
71
- const color = ColorPalette.green;
72
- const { wrapper } = setup({ icon: mdiAbTesting, color });
73
-
74
- expect(wrapper).toHaveClassName(
75
- getBasicClass({
76
- prefix: CLASSNAME,
77
- type: 'color',
78
- value: color,
79
- }),
80
- );
81
- });
82
- });
83
-
84
- // Common tests suite.
85
- commonTestsSuite(setup, { className: 'wrapper', prop: 'wrapper' }, { className: CLASSNAME });
86
- });
@@ -1,47 +0,0 @@
1
- import React, { forwardRef } from 'react';
2
- import classNames from 'classnames';
3
-
4
- import { ColorPalette, Icon, Size, Theme } from '@lumx/react';
5
- import { Comp, GenericProps, HasTheme } from '@lumx/react/utils/type';
6
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
7
-
8
- export interface FlagProps extends GenericProps, HasTheme {
9
- /** Color of the component. */
10
- color?: ColorPalette;
11
- /** Icon to use before the label. */
12
- icon?: string;
13
- /** Text label of the flag. */
14
- label: string;
15
- }
16
-
17
- const COMPONENT_NAME = 'Flag';
18
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
19
- const DEFAULT_PROPS: Partial<FlagProps> = {
20
- theme: Theme.light,
21
- };
22
-
23
- /**
24
- * Flag component.
25
- *
26
- * @param props Component props.
27
- * @param ref Component ref.
28
- * @return React element.
29
- */
30
- export const Flag: Comp<FlagProps, HTMLDivElement> = forwardRef((props, ref) => {
31
- const { label, icon, color, className, theme, ...forwardedProps } = props;
32
- const flagColor = color || (theme === Theme.light ? ColorPalette.dark : ColorPalette.light);
33
-
34
- return (
35
- <div
36
- {...forwardedProps}
37
- className={classNames(className, handleBasicClasses({ prefix: CLASSNAME, color: flagColor }))}
38
- ref={ref}
39
- >
40
- {icon && <Icon icon={icon} size={Size.xxs} className={`${CLASSNAME}__icon`} />}
41
- <span className={`${CLASSNAME}__label`}>{label}</span>
42
- </div>
43
- );
44
- });
45
- Flag.displayName = COMPONENT_NAME;
46
- Flag.className = CLASSNAME;
47
- Flag.defaultProps = DEFAULT_PROPS;