@lumx/react 3.1.0 → 3.1.2

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