@lumx/react 3.1.1 → 3.1.3-alpha.0

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