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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (502) hide show
  1. package/{dist/CONTRIBUTING.md → CONTRIBUTING.md} +0 -0
  2. package/{dist/LICENSE.md → LICENSE.md} +0 -0
  3. package/{dist/_internal → _internal}/ClickAwayProvider.js +0 -0
  4. package/{dist/_internal → _internal}/ClickAwayProvider.js.map +0 -0
  5. package/{dist/_internal → _internal}/types.d.ts +1 -1
  6. package/{dist/index.d.ts → index.d.ts} +7 -7
  7. package/{dist/index.js → index.js} +0 -0
  8. package/{dist/index.js.map → index.js.map} +1 -1
  9. package/package.json +3 -3
  10. package/src/components/badge/Badge.tsx +2 -2
  11. package/src/components/button/ButtonRoot.tsx +2 -2
  12. package/src/components/chip/Chip.tsx +2 -2
  13. package/src/components/icon/Icon.tsx +2 -2
  14. package/src/components/link/Link.tsx +2 -2
  15. package/{dist/utils → utils}/index.d.ts +0 -0
  16. package/{dist/utils → utils}/index.js +0 -0
  17. package/{dist/utils → utils}/index.js.map +0 -0
  18. package/dist/README.md +0 -38
  19. package/dist/package.json +0 -117
  20. package/dist/src/components/alert-dialog/AlertDialog.stories.tsx +0 -196
  21. package/dist/src/components/alert-dialog/AlertDialog.test.tsx +0 -43
  22. package/dist/src/components/alert-dialog/AlertDialog.tsx +0 -185
  23. package/dist/src/components/alert-dialog/__snapshots__/AlertDialog.test.tsx.snap +0 -551
  24. package/dist/src/components/alert-dialog/index.ts +0 -1
  25. package/dist/src/components/autocomplete/Autocomplete.stories.tsx +0 -70
  26. package/dist/src/components/autocomplete/Autocomplete.test.tsx +0 -181
  27. package/dist/src/components/autocomplete/Autocomplete.tsx +0 -292
  28. package/dist/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -170
  29. package/dist/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -94
  30. package/dist/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
  31. package/dist/src/components/autocomplete/__mockData__/index.ts +0 -34
  32. package/dist/src/components/autocomplete/__snapshots__/Autocomplete.test.tsx.snap +0 -213
  33. package/dist/src/components/autocomplete/__snapshots__/AutocompleteMultiple.test.tsx.snap +0 -88
  34. package/dist/src/components/autocomplete/index.ts +0 -2
  35. package/dist/src/components/avatar/Avatar.stories.tsx +0 -92
  36. package/dist/src/components/avatar/Avatar.test.tsx +0 -39
  37. package/dist/src/components/avatar/Avatar.tsx +0 -112
  38. package/dist/src/components/avatar/__snapshots__/Avatar.test.tsx.snap +0 -681
  39. package/dist/src/components/avatar/index.ts +0 -1
  40. package/dist/src/components/badge/Badge.stories.tsx +0 -45
  41. package/dist/src/components/badge/Badge.test.tsx +0 -91
  42. package/dist/src/components/badge/Badge.tsx +0 -55
  43. package/dist/src/components/badge/__snapshots__/Badge.test.tsx.snap +0 -11
  44. package/dist/src/components/badge/index.ts +0 -1
  45. package/dist/src/components/button/Button.stories.tsx +0 -156
  46. package/dist/src/components/button/Button.test.tsx +0 -152
  47. package/dist/src/components/button/Button.tsx +0 -81
  48. package/dist/src/components/button/ButtonGroup.test.tsx +0 -66
  49. package/dist/src/components/button/ButtonGroup.tsx +0 -46
  50. package/dist/src/components/button/ButtonRoot.test.tsx +0 -203
  51. package/dist/src/components/button/ButtonRoot.tsx +0 -190
  52. package/dist/src/components/button/IconButton.test.tsx +0 -103
  53. package/dist/src/components/button/IconButton.tsx +0 -80
  54. package/dist/src/components/button/__snapshots__/Button.test.tsx.snap +0 -96
  55. package/dist/src/components/button/__snapshots__/ButtonGroup.test.tsx.snap +0 -22
  56. package/dist/src/components/button/__snapshots__/ButtonRoot.test.tsx.snap +0 -160
  57. package/dist/src/components/button/__snapshots__/IconButton.test.tsx.snap +0 -83
  58. package/dist/src/components/button/index.ts +0 -4
  59. package/dist/src/components/checkbox/Checkbox.stories.tsx +0 -37
  60. package/dist/src/components/checkbox/Checkbox.test.tsx +0 -114
  61. package/dist/src/components/checkbox/Checkbox.tsx +0 -145
  62. package/dist/src/components/checkbox/__snapshots__/Checkbox.test.tsx.snap +0 -141
  63. package/dist/src/components/checkbox/index.ts +0 -1
  64. package/dist/src/components/chip/Chip.stories.tsx +0 -21
  65. package/dist/src/components/chip/Chip.test.tsx +0 -199
  66. package/dist/src/components/chip/Chip.tsx +0 -154
  67. package/dist/src/components/chip/ChipGroup.test.tsx +0 -29
  68. package/dist/src/components/chip/ChipGroup.tsx +0 -62
  69. package/dist/src/components/chip/__snapshots__/Chip.test.tsx.snap +0 -12
  70. package/dist/src/components/chip/__snapshots__/ChipGroup.test.tsx.snap +0 -29
  71. package/dist/src/components/chip/index.ts +0 -2
  72. package/dist/src/components/comment-block/CommentBlock.stories.tsx +0 -30
  73. package/dist/src/components/comment-block/CommentBlock.test.tsx +0 -28
  74. package/dist/src/components/comment-block/CommentBlock.tsx +0 -174
  75. package/dist/src/components/comment-block/__snapshots__/CommentBlock.test.tsx.snap +0 -92
  76. package/dist/src/components/comment-block/index.ts +0 -1
  77. package/dist/src/components/date-picker/DatePicker.test.tsx +0 -41
  78. package/dist/src/components/date-picker/DatePicker.tsx +0 -56
  79. package/dist/src/components/date-picker/DatePickerControlled.test.tsx +0 -44
  80. package/dist/src/components/date-picker/DatePickerControlled.tsx +0 -128
  81. package/dist/src/components/date-picker/DatePickerField.stories.tsx +0 -93
  82. package/dist/src/components/date-picker/DatePickerField.test.tsx +0 -47
  83. package/dist/src/components/date-picker/DatePickerField.tsx +0 -141
  84. package/dist/src/components/date-picker/__snapshots__/DatePicker.test.tsx.snap +0 -22
  85. package/dist/src/components/date-picker/__snapshots__/DatePickerControlled.test.tsx.snap +0 -597
  86. package/dist/src/components/date-picker/__snapshots__/DatePickerField.test.tsx.snap +0 -43
  87. package/dist/src/components/date-picker/constants.ts +0 -11
  88. package/dist/src/components/date-picker/index.ts +0 -4
  89. package/dist/src/components/date-picker/types.ts +0 -28
  90. package/dist/src/components/dialog/Dialog.stories.tsx +0 -426
  91. package/dist/src/components/dialog/Dialog.test.tsx +0 -93
  92. package/dist/src/components/dialog/Dialog.tsx +0 -263
  93. package/dist/src/components/dialog/__snapshots__/Dialog.test.tsx.snap +0 -960
  94. package/dist/src/components/dialog/index.ts +0 -1
  95. package/dist/src/components/divider/Divider.test.tsx +0 -93
  96. package/dist/src/components/divider/Divider.tsx +0 -51
  97. package/dist/src/components/divider/__snapshots__/Divider.test.tsx.snap +0 -9
  98. package/dist/src/components/divider/index.ts +0 -1
  99. package/dist/src/components/drag-handle/DragHandle.tsx +0 -50
  100. package/dist/src/components/drag-handle/index.ts +0 -1
  101. package/dist/src/components/dropdown/Dropdown.stories.tsx +0 -216
  102. package/dist/src/components/dropdown/Dropdown.test.tsx +0 -97
  103. package/dist/src/components/dropdown/Dropdown.tsx +0 -184
  104. package/dist/src/components/dropdown/__snapshots__/Dropdown.test.tsx.snap +0 -35
  105. package/dist/src/components/dropdown/index.ts +0 -1
  106. package/dist/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -116
  107. package/dist/src/components/expansion-panel/ExpansionPanel.tsx +0 -170
  108. package/dist/src/components/expansion-panel/index.ts +0 -1
  109. package/dist/src/components/flag/Flag.stories.tsx +0 -23
  110. package/dist/src/components/flag/Flag.test.tsx +0 -86
  111. package/dist/src/components/flag/Flag.tsx +0 -47
  112. package/dist/src/components/flag/__snapshots__/Flag.test.tsx.snap +0 -133
  113. package/dist/src/components/flag/index.ts +0 -1
  114. package/dist/src/components/flex-box/FlexBox.stories.tsx +0 -245
  115. package/dist/src/components/flex-box/FlexBox.test.tsx +0 -65
  116. package/dist/src/components/flex-box/FlexBox.tsx +0 -98
  117. package/dist/src/components/flex-box/__snapshots__/FlexBox.test.tsx.snap +0 -492
  118. package/dist/src/components/flex-box/index.ts +0 -1
  119. package/dist/src/components/generic-block/GenericBlock.stories.jsx +0 -128
  120. package/dist/src/components/generic-block/GenericBlock.test.tsx +0 -152
  121. package/dist/src/components/generic-block/GenericBlock.tsx +0 -222
  122. package/dist/src/components/generic-block/constants.ts +0 -9
  123. package/dist/src/components/generic-block/index.ts +0 -2
  124. package/dist/src/components/grid/Grid.tsx +0 -73
  125. package/dist/src/components/grid/GridItem.tsx +0 -54
  126. package/dist/src/components/grid/index.ts +0 -2
  127. package/dist/src/components/grid-column/GridColumn.stories.jsx +0 -56
  128. package/dist/src/components/grid-column/GridColumn.test.jsx +0 -58
  129. package/dist/src/components/grid-column/GridColumn.tsx +0 -90
  130. package/dist/src/components/grid-column/index.ts +0 -1
  131. package/dist/src/components/heading/Heading.stories.tsx +0 -108
  132. package/dist/src/components/heading/Heading.test.tsx +0 -82
  133. package/dist/src/components/heading/Heading.tsx +0 -63
  134. package/dist/src/components/heading/HeadingLevelProvider.tsx +0 -30
  135. package/dist/src/components/heading/constants.ts +0 -16
  136. package/dist/src/components/heading/context.tsx +0 -13
  137. package/dist/src/components/heading/index.ts +0 -3
  138. package/dist/src/components/heading/useHeadingLevel.tsx +0 -8
  139. package/dist/src/components/icon/Icon.stories.tsx +0 -76
  140. package/dist/src/components/icon/Icon.test.tsx +0 -102
  141. package/dist/src/components/icon/Icon.tsx +0 -121
  142. package/dist/src/components/icon/__snapshots__/Icon.test.tsx.snap +0 -49
  143. package/dist/src/components/icon/index.ts +0 -1
  144. package/dist/src/components/image-block/ImageBlock.stories.tsx +0 -52
  145. package/dist/src/components/image-block/ImageBlock.test.tsx +0 -28
  146. package/dist/src/components/image-block/ImageBlock.tsx +0 -151
  147. package/dist/src/components/image-block/__snapshots__/ImageBlock.test.tsx.snap +0 -64
  148. package/dist/src/components/image-block/index.ts +0 -1
  149. package/dist/src/components/index.ts +0 -176
  150. package/dist/src/components/inline-list/InlineList.stories.tsx +0 -40
  151. package/dist/src/components/inline-list/InlineList.test.tsx +0 -41
  152. package/dist/src/components/inline-list/InlineList.tsx +0 -82
  153. package/dist/src/components/inline-list/index.ts +0 -1
  154. package/dist/src/components/input-helper/InputHelper.stories.tsx +0 -29
  155. package/dist/src/components/input-helper/InputHelper.test.tsx +0 -107
  156. package/dist/src/components/input-helper/InputHelper.tsx +0 -61
  157. package/dist/src/components/input-helper/__snapshots__/InputHelper.test.tsx.snap +0 -9
  158. package/dist/src/components/input-helper/constants.ts +0 -11
  159. package/dist/src/components/input-helper/index.ts +0 -1
  160. package/dist/src/components/input-label/InputLabel.stories.tsx +0 -15
  161. package/dist/src/components/input-label/InputLabel.test.tsx +0 -86
  162. package/dist/src/components/input-label/InputLabel.tsx +0 -59
  163. package/dist/src/components/input-label/__snapshots__/InputLabel.test.tsx.snap +0 -10
  164. package/dist/src/components/input-label/index.ts +0 -1
  165. package/dist/src/components/lightbox/Lightbox.stories.tsx +0 -83
  166. package/dist/src/components/lightbox/Lightbox.test.tsx +0 -30
  167. package/dist/src/components/lightbox/Lightbox.tsx +0 -153
  168. package/dist/src/components/lightbox/__snapshots__/Lightbox.test.tsx.snap +0 -194
  169. package/dist/src/components/lightbox/index.ts +0 -1
  170. package/dist/src/components/link/Link.stories.tsx +0 -141
  171. package/dist/src/components/link/Link.test.tsx +0 -60
  172. package/dist/src/components/link/Link.tsx +0 -156
  173. package/dist/src/components/link/__snapshots__/Link.test.tsx.snap +0 -29
  174. package/dist/src/components/link/index.ts +0 -1
  175. package/dist/src/components/link-preview/LinkPreview.stories.tsx +0 -88
  176. package/dist/src/components/link-preview/LinkPreview.test.tsx +0 -102
  177. package/dist/src/components/link-preview/LinkPreview.tsx +0 -158
  178. package/dist/src/components/link-preview/index.ts +0 -1
  179. package/dist/src/components/list/List.stories.tsx +0 -141
  180. package/dist/src/components/list/List.test.tsx +0 -29
  181. package/dist/src/components/list/List.tsx +0 -94
  182. package/dist/src/components/list/ListDivider.stories.tsx +0 -7
  183. package/dist/src/components/list/ListDivider.test.tsx +0 -29
  184. package/dist/src/components/list/ListDivider.tsx +0 -42
  185. package/dist/src/components/list/ListItem.stories.tsx +0 -62
  186. package/dist/src/components/list/ListItem.test.tsx +0 -29
  187. package/dist/src/components/list/ListItem.tsx +0 -154
  188. package/dist/src/components/list/ListSubheader.stories.tsx +0 -8
  189. package/dist/src/components/list/ListSubheader.test.tsx +0 -29
  190. package/dist/src/components/list/ListSubheader.tsx +0 -43
  191. package/dist/src/components/list/__snapshots__/List.test.tsx.snap +0 -360
  192. package/dist/src/components/list/__snapshots__/ListDivider.test.tsx.snap +0 -7
  193. package/dist/src/components/list/__snapshots__/ListItem.test.tsx.snap +0 -160
  194. package/dist/src/components/list/__snapshots__/ListSubheader.test.tsx.snap +0 -9
  195. package/dist/src/components/list/index.ts +0 -4
  196. package/dist/src/components/list/useInteractiveList.tsx +0 -202
  197. package/dist/src/components/message/Message.stories.tsx +0 -27
  198. package/dist/src/components/message/Message.test.tsx +0 -76
  199. package/dist/src/components/message/Message.tsx +0 -74
  200. package/dist/src/components/message/__snapshots__/Message.test.tsx.snap +0 -15
  201. package/dist/src/components/message/index.ts +0 -1
  202. package/dist/src/components/mosaic/Mosaic.stories.tsx +0 -85
  203. package/dist/src/components/mosaic/Mosaic.test.tsx +0 -120
  204. package/dist/src/components/mosaic/Mosaic.tsx +0 -95
  205. package/dist/src/components/mosaic/__snapshots__/Mosaic.test.tsx.snap +0 -357
  206. package/dist/src/components/mosaic/index.ts +0 -1
  207. package/dist/src/components/notification/Notification.test.tsx +0 -108
  208. package/dist/src/components/notification/Notification.tsx +0 -130
  209. package/dist/src/components/notification/Notifications.stories.tsx +0 -77
  210. package/dist/src/components/notification/__snapshots__/Notification.test.tsx.snap +0 -34
  211. package/dist/src/components/notification/constants.ts +0 -28
  212. package/dist/src/components/notification/index.ts +0 -1
  213. package/dist/src/components/popover/Popover.stories.tsx +0 -386
  214. package/dist/src/components/popover/Popover.test.tsx +0 -30
  215. package/dist/src/components/popover/Popover.tsx +0 -382
  216. package/dist/src/components/popover/__snapshots__/Popover.test.tsx.snap +0 -343
  217. package/dist/src/components/popover/index.ts +0 -1
  218. package/dist/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -75
  219. package/dist/src/components/popover-dialog/PopoverDialog.test.tsx +0 -65
  220. package/dist/src/components/popover-dialog/PopoverDialog.tsx +0 -65
  221. package/dist/src/components/popover-dialog/index.tsx +0 -1
  222. package/dist/src/components/post-block/PostBlock.test.tsx +0 -28
  223. package/dist/src/components/post-block/PostBlock.tsx +0 -123
  224. package/dist/src/components/post-block/__snapshots__/PostBlock.test.tsx.snap +0 -139
  225. package/dist/src/components/post-block/index.ts +0 -1
  226. package/dist/src/components/progress/Progress.tsx +0 -68
  227. package/dist/src/components/progress/ProgressCircular.stories.tsx +0 -18
  228. package/dist/src/components/progress/ProgressCircular.test.tsx +0 -49
  229. package/dist/src/components/progress/ProgressCircular.tsx +0 -68
  230. package/dist/src/components/progress/ProgressLinear.stories.tsx +0 -8
  231. package/dist/src/components/progress/ProgressLinear.test.tsx +0 -37
  232. package/dist/src/components/progress/ProgressLinear.tsx +0 -52
  233. package/dist/src/components/progress/index.ts +0 -3
  234. package/dist/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
  235. package/dist/src/components/progress-tracker/ProgressTracker.test.tsx +0 -57
  236. package/dist/src/components/progress-tracker/ProgressTracker.tsx +0 -89
  237. package/dist/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -42
  238. package/dist/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -66
  239. package/dist/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -128
  240. package/dist/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
  241. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -73
  242. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -67
  243. package/dist/src/components/progress-tracker/__snapshots__/ProgressTracker.test.tsx.snap +0 -41
  244. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStep.test.tsx.snap +0 -141
  245. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStepPanel.test.tsx.snap +0 -25
  246. package/dist/src/components/progress-tracker/index.ts +0 -4
  247. package/dist/src/components/radio-button/RadioButton.stories.tsx +0 -28
  248. package/dist/src/components/radio-button/RadioButton.test.tsx +0 -123
  249. package/dist/src/components/radio-button/RadioButton.tsx +0 -141
  250. package/dist/src/components/radio-button/RadioGroup.stories.tsx +0 -42
  251. package/dist/src/components/radio-button/RadioGroup.test.tsx +0 -77
  252. package/dist/src/components/radio-button/RadioGroup.tsx +0 -52
  253. package/dist/src/components/radio-button/__snapshots__/RadioButton.test.tsx.snap +0 -113
  254. package/dist/src/components/radio-button/__snapshots__/RadioGroup.test.tsx.snap +0 -26
  255. package/dist/src/components/radio-button/index.ts +0 -2
  256. package/dist/src/components/select/Select.stories.tsx +0 -399
  257. package/dist/src/components/select/Select.test.tsx +0 -359
  258. package/dist/src/components/select/Select.tsx +0 -193
  259. package/dist/src/components/select/SelectMultiple.stories.tsx +0 -227
  260. package/dist/src/components/select/SelectMultiple.test.tsx +0 -405
  261. package/dist/src/components/select/SelectMultiple.tsx +0 -198
  262. package/dist/src/components/select/WithSelectContext.tsx +0 -143
  263. package/dist/src/components/select/__snapshots__/Select.test.tsx.snap +0 -43
  264. package/dist/src/components/select/__snapshots__/SelectMultiple.test.tsx.snap +0 -87
  265. package/dist/src/components/select/constants.ts +0 -53
  266. package/dist/src/components/select/index.ts +0 -2
  267. package/dist/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
  268. package/dist/src/components/side-navigation/SideNavigation.test.tsx +0 -52
  269. package/dist/src/components/side-navigation/SideNavigation.tsx +0 -54
  270. package/dist/src/components/side-navigation/SideNavigationItem.test.tsx +0 -175
  271. package/dist/src/components/side-navigation/SideNavigationItem.tsx +0 -162
  272. package/dist/src/components/side-navigation/__snapshots__/SideNavigation.test.tsx.snap +0 -7
  273. package/dist/src/components/side-navigation/__snapshots__/SideNavigationItem.test.tsx.snap +0 -30
  274. package/dist/src/components/side-navigation/index.ts +0 -2
  275. package/dist/src/components/skeleton/SkeletonCircle.stories.tsx +0 -25
  276. package/dist/src/components/skeleton/SkeletonCircle.test.tsx +0 -28
  277. package/dist/src/components/skeleton/SkeletonCircle.tsx +0 -52
  278. package/dist/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -107
  279. package/dist/src/components/skeleton/SkeletonRectangle.test.tsx +0 -28
  280. package/dist/src/components/skeleton/SkeletonRectangle.tsx +0 -78
  281. package/dist/src/components/skeleton/SkeletonTypography.stories.tsx +0 -26
  282. package/dist/src/components/skeleton/SkeletonTypography.test.tsx +0 -28
  283. package/dist/src/components/skeleton/SkeletonTypography.tsx +0 -57
  284. package/dist/src/components/skeleton/__snapshots__/SkeletonCircle.test.tsx.snap +0 -54
  285. package/dist/src/components/skeleton/__snapshots__/SkeletonRectangle.test.tsx.snap +0 -177
  286. package/dist/src/components/skeleton/__snapshots__/SkeletonTypography.test.tsx.snap +0 -174
  287. package/dist/src/components/skeleton/index.ts +0 -3
  288. package/dist/src/components/slider/Slider.stories.tsx +0 -29
  289. package/dist/src/components/slider/Slider.test.tsx +0 -31
  290. package/dist/src/components/slider/Slider.tsx +0 -299
  291. package/dist/src/components/slider/__snapshots__/Slider.test.tsx.snap +0 -122
  292. package/dist/src/components/slider/index.ts +0 -2
  293. package/dist/src/components/slideshow/Slides.tsx +0 -124
  294. package/dist/src/components/slideshow/Slideshow.stories.tsx +0 -212
  295. package/dist/src/components/slideshow/Slideshow.test.tsx +0 -39
  296. package/dist/src/components/slideshow/Slideshow.tsx +0 -170
  297. package/dist/src/components/slideshow/SlideshowControls.stories.tsx +0 -112
  298. package/dist/src/components/slideshow/SlideshowControls.tsx +0 -241
  299. package/dist/src/components/slideshow/SlideshowItem.tsx +0 -52
  300. package/dist/src/components/slideshow/SlideshowItemGroup.tsx +0 -64
  301. package/dist/src/components/slideshow/__snapshots__/Slideshow.test.tsx.snap +0 -157
  302. package/dist/src/components/slideshow/constants.ts +0 -24
  303. package/dist/src/components/slideshow/index.ts +0 -4
  304. package/dist/src/components/slideshow/useKeyNavigate.ts +0 -28
  305. package/dist/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
  306. package/dist/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
  307. package/dist/src/components/slideshow/useSwipeNavigate.ts +0 -18
  308. package/dist/src/components/switch/Switch.stories.tsx +0 -36
  309. package/dist/src/components/switch/Switch.test.tsx +0 -189
  310. package/dist/src/components/switch/Switch.tsx +0 -141
  311. package/dist/src/components/switch/__snapshots__/Switch.test.tsx.snap +0 -179
  312. package/dist/src/components/switch/index.ts +0 -1
  313. package/dist/src/components/table/Table.test.tsx +0 -28
  314. package/dist/src/components/table/Table.tsx +0 -59
  315. package/dist/src/components/table/TableBody.test.tsx +0 -22
  316. package/dist/src/components/table/TableBody.tsx +0 -44
  317. package/dist/src/components/table/TableCell.test.tsx +0 -23
  318. package/dist/src/components/table/TableCell.tsx +0 -125
  319. package/dist/src/components/table/TableHeader.test.tsx +0 -22
  320. package/dist/src/components/table/TableHeader.tsx +0 -50
  321. package/dist/src/components/table/TableRow.test.tsx +0 -22
  322. package/dist/src/components/table/TableRow.tsx +0 -68
  323. package/dist/src/components/table/__snapshots__/Table.test.tsx.snap +0 -263
  324. package/dist/src/components/table/index.ts +0 -5
  325. package/dist/src/components/tabs/Tab.test.tsx +0 -116
  326. package/dist/src/components/tabs/Tab.tsx +0 -120
  327. package/dist/src/components/tabs/TabList.test.tsx +0 -80
  328. package/dist/src/components/tabs/TabList.tsx +0 -82
  329. package/dist/src/components/tabs/TabPanel.test.tsx +0 -74
  330. package/dist/src/components/tabs/TabPanel.tsx +0 -65
  331. package/dist/src/components/tabs/TabProvider.test.tsx +0 -42
  332. package/dist/src/components/tabs/TabProvider.tsx +0 -59
  333. package/dist/src/components/tabs/Tabs.stories.tsx +0 -134
  334. package/dist/src/components/tabs/__snapshots__/Tab.test.tsx.snap +0 -62
  335. package/dist/src/components/tabs/__snapshots__/TabList.test.tsx.snap +0 -22
  336. package/dist/src/components/tabs/__snapshots__/TabPanel.test.tsx.snap +0 -25
  337. package/dist/src/components/tabs/index.ts +0 -4
  338. package/dist/src/components/tabs/state.ts +0 -116
  339. package/dist/src/components/tabs/test.mocks.ts +0 -33
  340. package/dist/src/components/text/Text.stories.jsx +0 -75
  341. package/dist/src/components/text/Text.test.tsx +0 -108
  342. package/dist/src/components/text/Text.tsx +0 -121
  343. package/dist/src/components/text/index.ts +0 -1
  344. package/dist/src/components/text-field/TextField.stories.tsx +0 -169
  345. package/dist/src/components/text-field/TextField.test.tsx +0 -171
  346. package/dist/src/components/text-field/TextField.tsx +0 -432
  347. package/dist/src/components/text-field/__snapshots__/TextField.test.tsx.snap +0 -42
  348. package/dist/src/components/text-field/index.ts +0 -1
  349. package/dist/src/components/thumbnail/Thumbnail.stories.tsx +0 -510
  350. package/dist/src/components/thumbnail/Thumbnail.test.tsx +0 -46
  351. package/dist/src/components/thumbnail/Thumbnail.tsx +0 -222
  352. package/dist/src/components/thumbnail/__snapshots__/Thumbnail.test.tsx.snap +0 -130
  353. package/dist/src/components/thumbnail/index.ts +0 -3
  354. package/dist/src/components/thumbnail/types.ts +0 -39
  355. package/dist/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
  356. package/dist/src/components/thumbnail/useFocusPointStyle.tsx +0 -111
  357. package/dist/src/components/thumbnail/useImageLoad.ts +0 -40
  358. package/dist/src/components/toolbar/Toolbar.tsx +0 -67
  359. package/dist/src/components/toolbar/index.ts +0 -1
  360. package/dist/src/components/tooltip/Tooltip.stories.tsx +0 -172
  361. package/dist/src/components/tooltip/Tooltip.test.tsx +0 -105
  362. package/dist/src/components/tooltip/Tooltip.tsx +0 -122
  363. package/dist/src/components/tooltip/__snapshots__/Tooltip.test.tsx.snap +0 -233
  364. package/dist/src/components/tooltip/index.ts +0 -1
  365. package/dist/src/components/tooltip/useInjectTooltipRef.tsx +0 -44
  366. package/dist/src/components/tooltip/useTooltipOpen.tsx +0 -113
  367. package/dist/src/components/uploader/Uploader.test.tsx +0 -87
  368. package/dist/src/components/uploader/Uploader.tsx +0 -105
  369. package/dist/src/components/uploader/__snapshots__/Uploader.test.tsx.snap +0 -14
  370. package/dist/src/components/uploader/index.ts +0 -1
  371. package/dist/src/components/user-block/UserBlock.stories.tsx +0 -76
  372. package/dist/src/components/user-block/UserBlock.test.tsx +0 -38
  373. package/dist/src/components/user-block/UserBlock.tsx +0 -179
  374. package/dist/src/components/user-block/__snapshots__/UserBlock.test.tsx.snap +0 -362
  375. package/dist/src/components/user-block/index.ts +0 -1
  376. package/dist/src/constants.ts +0 -17
  377. package/dist/src/hooks/useBooleanState.tsx +0 -13
  378. package/dist/src/hooks/useCallbackOnEscape.ts +0 -34
  379. package/dist/src/hooks/useChipGroupNavigation.tsx +0 -75
  380. package/dist/src/hooks/useClickAway.tsx +0 -47
  381. package/dist/src/hooks/useDisableBodyScroll.ts +0 -28
  382. package/dist/src/hooks/useEventCallback.tsx +0 -17
  383. package/dist/src/hooks/useFocus.tsx +0 -21
  384. package/dist/src/hooks/useFocusTrap.ts +0 -85
  385. package/dist/src/hooks/useFocusWithin.ts +0 -33
  386. package/dist/src/hooks/useInfiniteScroll.tsx +0 -60
  387. package/dist/src/hooks/useIntersectionObserver.tsx +0 -43
  388. package/dist/src/hooks/useInterval.tsx +0 -31
  389. package/dist/src/hooks/useKeyboardListNavigation.tsx +0 -204
  390. package/dist/src/hooks/useListenFocus.tsx +0 -26
  391. package/dist/src/hooks/useOnResize.ts +0 -41
  392. package/dist/src/hooks/useRovingTabIndex.tsx +0 -90
  393. package/dist/src/hooks/useSlideshowControls.ts +0 -243
  394. package/dist/src/hooks/useStopPropagation.ts +0 -21
  395. package/dist/src/hooks/useTransitionVisibility.ts +0 -54
  396. package/dist/src/index.ts +0 -58
  397. package/dist/src/stories/chromaticForceScreenSize.tsx +0 -7
  398. package/dist/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
  399. package/dist/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
  400. package/dist/src/stories/generated/Badge/Demos.stories.tsx +0 -9
  401. package/dist/src/stories/generated/Button/Demos.stories.tsx +0 -11
  402. package/dist/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
  403. package/dist/src/stories/generated/Chip/Demos.stories.tsx +0 -11
  404. package/dist/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
  405. package/dist/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
  406. package/dist/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
  407. package/dist/src/stories/generated/Divider/Demos.stories.tsx +0 -6
  408. package/dist/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
  409. package/dist/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
  410. package/dist/src/stories/generated/Flag/Demos.stories.tsx +0 -6
  411. package/dist/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
  412. package/dist/src/stories/generated/Heading/Demos.stories.tsx +0 -6
  413. package/dist/src/stories/generated/Icon/Demos.stories.tsx +0 -8
  414. package/dist/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
  415. package/dist/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
  416. package/dist/src/stories/generated/Link/Demos.stories.tsx +0 -8
  417. package/dist/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
  418. package/dist/src/stories/generated/List/Demos.stories.tsx +0 -11
  419. package/dist/src/stories/generated/Message/Demos.stories.tsx +0 -10
  420. package/dist/src/stories/generated/Mosaic/Demos.stories.tsx +0 -9
  421. package/dist/src/stories/generated/Notification/Demos.stories.tsx +0 -6
  422. package/dist/src/stories/generated/Popover/Demos.stories.tsx +0 -11
  423. package/dist/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
  424. package/dist/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
  425. package/dist/src/stories/generated/Progress/Demos.stories.tsx +0 -7
  426. package/dist/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
  427. package/dist/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
  428. package/dist/src/stories/generated/Select/Demos.stories.tsx +0 -14
  429. package/dist/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
  430. package/dist/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
  431. package/dist/src/stories/generated/Slider/Demos.stories.tsx +0 -9
  432. package/dist/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
  433. package/dist/src/stories/generated/Switch/Demos.stories.tsx +0 -6
  434. package/dist/src/stories/generated/Table/Demos.stories.tsx +0 -6
  435. package/dist/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
  436. package/dist/src/stories/generated/TextField/Demos.stories.tsx +0 -19
  437. package/dist/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
  438. package/dist/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
  439. package/dist/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
  440. package/dist/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
  441. package/dist/src/stories/generated/UserBlock/Demos.stories.tsx +0 -10
  442. package/dist/src/stories/knobs/buttonKnob.ts +0 -9
  443. package/dist/src/stories/knobs/emphasisKnob.ts +0 -8
  444. package/dist/src/stories/knobs/enumKnob.ts +0 -14
  445. package/dist/src/stories/knobs/focusKnob.ts +0 -3
  446. package/dist/src/stories/knobs/image.ts +0 -69
  447. package/dist/src/stories/knobs/lorem.ts +0 -59
  448. package/dist/src/stories/knobs/sizeKnob.ts +0 -5
  449. package/dist/src/stories/knobs/thumbnailsKnob.ts +0 -9
  450. package/dist/src/stories/utils/CustomLink.tsx +0 -7
  451. package/dist/src/stories/withResizableBox.tsx +0 -18
  452. package/dist/src/testing/utils/commonTestsSuite.ts +0 -71
  453. package/dist/src/testing/utils/commonTestsSuiteRTL.ts +0 -55
  454. package/dist/src/testing/utils/index.ts +0 -4
  455. package/dist/src/testing/utils/itShouldRenderStories.tsx +0 -103
  456. package/dist/src/testing/utils/queries.ts +0 -19
  457. package/dist/src/untypped-modules.d.ts +0 -7
  458. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -58
  459. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -65
  460. package/dist/src/utils/ClickAwayProvider/index.ts +0 -1
  461. package/dist/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
  462. package/dist/src/utils/MaterialThemeSwitcher/index.ts +0 -1
  463. package/dist/src/utils/browserDoesNotSupportHover.test.js +0 -24
  464. package/dist/src/utils/browserDoesNotSupportHover.ts +0 -2
  465. package/dist/src/utils/clamp.ts +0 -17
  466. package/dist/src/utils/className.ts +0 -44
  467. package/dist/src/utils/event.ts +0 -1
  468. package/dist/src/utils/flattenChildren.test.tsx +0 -58
  469. package/dist/src/utils/flattenChildren.ts +0 -27
  470. package/dist/src/utils/focus/constants.ts +0 -5
  471. package/dist/src/utils/focus/getFirstAndLastFocusable.test.ts +0 -134
  472. package/dist/src/utils/focus/getFirstAndLastFocusable.ts +0 -21
  473. package/dist/src/utils/focus/getFocusableElements.test.ts +0 -151
  474. package/dist/src/utils/focus/getFocusableElements.ts +0 -7
  475. package/dist/src/utils/index.ts +0 -5
  476. package/dist/src/utils/isInternetExplorer.ts +0 -15
  477. package/dist/src/utils/makeListenerTowerContext.ts +0 -32
  478. package/dist/src/utils/mergeRefs.ts +0 -22
  479. package/dist/src/utils/partitionMulti.ts +0 -28
  480. package/dist/src/utils/renderLink.tsx +0 -17
  481. package/dist/src/utils/type.ts +0 -113
  482. package/dist/src/utils/userHasReducedMotion.ts +0 -7
  483. package/dist/src/utils/utils.test.ts +0 -48
  484. package/jest/__mocks__/@storybook/addon-actions.js +0 -3
  485. package/jest/__mocks__/@storybook/addon-knobs.js +0 -6
  486. package/jest/__mocks__/emptyFileMockTransformer.js +0 -8
  487. package/jest/__mocks__/emptyModuleMock.js +0 -1
  488. package/jest/configure.js +0 -6
  489. package/jest/index.js +0 -36
  490. package/jest/transform.js +0 -6
  491. package/rollup.config.js +0 -98
  492. package/storybook/build +0 -4
  493. package/storybook/generate-demo-stories.js +0 -59
  494. package/storybook/main.js +0 -67
  495. package/storybook/package.json +0 -13
  496. package/storybook/preview.js +0 -11
  497. package/storybook/start +0 -4
  498. package/storybook/story-block/StoryBlock.tsx +0 -49
  499. package/storybook/story-block/decorator.jsx +0 -7
  500. package/storybook/story-block/index.scss +0 -27
  501. package/storybook/yarn.lock +0 -13192
  502. package/tsconfig.json +0 -3
@@ -1,74 +0,0 @@
1
- import { Wrapper, commonTestsSuite } from '@lumx/react/testing/utils';
2
- import { mount, shallow } from 'enzyme';
3
- import 'jest-enzyme';
4
- import React, { ReactElement } from 'react';
5
-
6
- import { TabPanel, TabPanelProps } from './TabPanel';
7
- import { setupTabProviderMocks } from './test.mocks';
8
-
9
- const CLASSNAME = TabPanel.className as string;
10
-
11
- // Mock useTabProviderContext.
12
- jest.mock('./state', () => {
13
- const state = jest.requireActual('./state');
14
- return { ...state, useTabProviderContext: jest.fn(), useTabProviderContextState: jest.fn() };
15
- });
16
-
17
- type SetupProps = Partial<TabPanelProps>;
18
-
19
- /**
20
- * Mounts the component and returns common DOM elements / data needed in multiple tests further down.
21
- */
22
- const setup = ({ ...propsOverride }: SetupProps = {}, shallowRendering = true) => {
23
- const props: TabPanelProps = { ...propsOverride, children: 'Tab panel content' };
24
- const renderer: (el: ReactElement) => Wrapper = shallowRendering ? shallow : mount;
25
- const wrapper: Wrapper = renderer(<TabPanel {...props} />);
26
-
27
- return { props, wrapper };
28
- };
29
-
30
- describe(`<${TabPanel.displayName}>`, () => {
31
- // 1. Test render via snapshot (default states of component).
32
- describe('Snapshots and structure', () => {
33
- it('should render correctly', () => {
34
- setupTabProviderMocks({ index: 1 });
35
- const { wrapper } = setup();
36
- expect(wrapper).toMatchSnapshot();
37
- expect(wrapper).toHaveClassName(CLASSNAME);
38
- });
39
-
40
- it('should render isActive state', () => {
41
- setupTabProviderMocks({ index: 2, isActive: true });
42
- const { wrapper } = setup();
43
- expect(wrapper).toMatchSnapshot();
44
- });
45
-
46
- it('should not render children when not active and lazy', () => {
47
- setupTabProviderMocks({ isLazy: true, isActive: false });
48
- const { wrapper } = setup();
49
- expect(wrapper.find('div').props().children).toBeFalsy();
50
- });
51
-
52
- it('should render children when active and lazy', () => {
53
- setupTabProviderMocks({ isLazy: true, isActive: true });
54
- const { wrapper } = setup();
55
- expect(wrapper.find('div').props().children).toBeTruthy();
56
- });
57
-
58
- it('should render children when not active and not lazy', () => {
59
- setupTabProviderMocks({ isActive: false, isLazy: false });
60
- const { wrapper } = setup();
61
- expect(wrapper.find('div').props().children).toBeTruthy();
62
- });
63
- });
64
-
65
- // Common tests suite.
66
- commonTestsSuite(
67
- (...args: any[]) => {
68
- setupTabProviderMocks();
69
- return setup(...args);
70
- },
71
- { className: 'wrapper', prop: 'wrapper' },
72
- { className: CLASSNAME },
73
- );
74
- });
@@ -1,65 +0,0 @@
1
- import { useTabProviderContext } from '@lumx/react/components/tabs/state';
2
- import { CSS_PREFIX } from '@lumx/react/constants';
3
- import { Comp, GenericProps } from '@lumx/react/utils/type';
4
- import { handleBasicClasses } from '@lumx/react/utils/className';
5
-
6
- import classNames from 'classnames';
7
- import React, { forwardRef } from 'react';
8
-
9
- /**
10
- * Defines the props of the component.
11
- */
12
- export interface TabPanelProps extends GenericProps {
13
- /** Native id property */
14
- id?: string;
15
- /** Whether the tab is active or not. */
16
- isActive?: boolean;
17
- }
18
-
19
- /**
20
- * Component display name.
21
- */
22
- const COMPONENT_NAME = 'TabPanel';
23
-
24
- /**
25
- * Component default class name and class prefix.
26
- */
27
- const CLASSNAME = `${CSS_PREFIX}-tab-panel`;
28
-
29
- /**
30
- * Component default props.
31
- */
32
- const DEFAULT_PROPS: Partial<TabPanelProps> = {};
33
-
34
- /**
35
- * TabPanel component.
36
- *
37
- * Implements WAI-ARIA `tabpanel` role {@see https://www.w3.org/TR/wai-aria-practices-1.1/examples/tabs/tabs-1/tabs.html#rps_label}
38
- *
39
- * @param props Component props.
40
- * @param ref Component ref.
41
- * @return React element.
42
- */
43
- export const TabPanel: Comp<TabPanelProps, HTMLDivElement> = forwardRef((props, ref) => {
44
- const { children, id, className, isActive: propIsActive, ...forwardedProps } = props;
45
-
46
- const state = useTabProviderContext('tabPanel', id);
47
- const isActive = propIsActive || state?.isActive;
48
-
49
- return (
50
- <div
51
- ref={ref}
52
- {...forwardedProps}
53
- id={state?.tabPanelId}
54
- className={classNames(className, handleBasicClasses({ prefix: CLASSNAME, isActive }))}
55
- role="tabpanel"
56
- tabIndex={0}
57
- aria-labelledby={state?.tabId}
58
- >
59
- {(!state?.isLazy || isActive) && children}
60
- </div>
61
- );
62
- });
63
- TabPanel.displayName = COMPONENT_NAME;
64
- TabPanel.className = CLASSNAME;
65
- TabPanel.defaultProps = DEFAULT_PROPS;
@@ -1,42 +0,0 @@
1
- import { Tab, TabList, TabPanel, TabProvider } from '@lumx/react';
2
- import { mount } from 'enzyme';
3
- import 'jest-enzyme';
4
- import React from 'react';
5
-
6
- describe(`<${TabProvider.displayName}>`, () => {
7
- // 1. Test render via snapshot (default states of component).
8
- describe('Snapshots and structure', () => {
9
- it('should render', () => {
10
- const wrapper = mount(
11
- <TabProvider>
12
- <TabList aria-label="Tab list">
13
- <Tab label="tab 1" />
14
- <Tab label="tab 1" />
15
- </TabList>
16
-
17
- <TabPanel>Tab 1 content</TabPanel>
18
- <TabPanel>Tab 2 content</TabPanel>
19
- </TabProvider>,
20
- );
21
- const tabs = wrapper.find(Tab).find('button');
22
- const firstTab = tabs.get(0);
23
- const secondTab = tabs.get(1);
24
-
25
- const tabPanels = wrapper.find(TabPanel).find('div');
26
- const firstTabPanel = tabPanels.get(0);
27
- const secondTabPanel = tabPanels.get(1);
28
-
29
- // First tab is selected.
30
- expect(firstTab.props['aria-selected']).toBe(true);
31
- expect(secondTab.props['aria-selected']).toBe(false);
32
-
33
- // Tab id and tab panel aria-labelledby by should match
34
- expect(firstTab.props.id).toBe(firstTabPanel.props['aria-labelledby']);
35
- expect(secondTab.props.id).toBe(secondTabPanel.props['aria-labelledby']);
36
-
37
- // Tab panel id and tab aria-controls by should match
38
- expect(firstTabPanel.props.id).toBe(firstTab.props['aria-controls']);
39
- expect(secondTabPanel.props.id).toBe(secondTab.props['aria-controls']);
40
- });
41
- });
42
- });
@@ -1,59 +0,0 @@
1
- import React, { ReactNode, useEffect, useReducer } from 'react';
2
- import { INIT_STATE, TabProviderContext, reducer } from './state';
3
-
4
- export interface TabProviderProps {
5
- /** Active tab index. */
6
- activeTabIndex?: number;
7
- /** Tab provider children. */
8
- children: ReactNode;
9
- /** Tab panel children should not render if the tab panel is hidden. */
10
- isLazy?: boolean;
11
- /** Activate tabs on focus. */
12
- shouldActivateOnFocus?: boolean;
13
-
14
- /** Tab change callback. */
15
- onChange?(index: number): void;
16
- }
17
-
18
- const DEFAULT_PROPS: Partial<TabProviderProps> = {
19
- isLazy: INIT_STATE.isLazy,
20
- shouldActivateOnFocus: INIT_STATE.shouldActivateOnFocus,
21
- };
22
-
23
- /**
24
- * This component provides a context in which tabs can be defined and linked to their tab panel.
25
- *
26
- * It does not produce any markup so you can wrap it around any React elements and then split the TabList and TabPanel
27
- * components in the react tree.
28
- *
29
- * @param props React component props.
30
- * @return React element.
31
- */
32
- export const TabProvider: React.FC<TabProviderProps> = (props) => {
33
- const { children, onChange, ...propState } = props;
34
- const [state, dispatch] = useReducer(reducer, INIT_STATE);
35
-
36
- // On prop state change => dispatch update.
37
- useEffect(
38
- () => {
39
- dispatch({ type: 'update', payload: propState });
40
- },
41
- // eslint-disable-next-line react-hooks/exhaustive-deps
42
- [dispatch, ...Object.values(propState)],
43
- );
44
-
45
- // On active tab index state change => send update to the onChange.
46
- useEffect(
47
- () => {
48
- if (state === INIT_STATE || !onChange || propState.activeTabIndex === state.activeTabIndex) {
49
- return;
50
- }
51
- onChange(state.activeTabIndex);
52
- },
53
- // eslint-disable-next-line react-hooks/exhaustive-deps
54
- [onChange, state.activeTabIndex],
55
- );
56
-
57
- return <TabProviderContext.Provider value={[state, dispatch]}>{children}</TabProviderContext.Provider>;
58
- };
59
- TabProvider.defaultProps = DEFAULT_PROPS;
@@ -1,134 +0,0 @@
1
- import { Button, Dialog, Tab, TabList, TabPanel, TabProvider } from '@lumx/react';
2
- import { number } from '@storybook/addon-knobs';
3
- import get from 'lodash/get';
4
- import times from 'lodash/times';
5
- import React, { useState } from 'react';
6
-
7
- export default { title: 'LumX components/tabs' };
8
-
9
- /* Control active tab externally (with activate tab on focus). */
10
- export const Controlled = ({ theme }: any) => {
11
- const [activeTab, setActiveTab] = useState(1);
12
- const changeActiveTabIndex = (evt: any) => setActiveTab(parseInt(get(evt, 'target.value', '0'), 10));
13
-
14
- const [isLazy, setIsLazy] = useState(true);
15
- const changeIsLazy = (evt: any) => setIsLazy(get(evt, 'target.checked'));
16
-
17
- const [shouldActivateOnFocus, setShouldActivateOnFocus] = useState(true);
18
- const changeShouldActivateOnFocus = (evt: any) => setShouldActivateOnFocus(get(evt, 'target.checked'));
19
-
20
- return (
21
- <>
22
- <div>
23
- Active tab index:
24
- <input type="number" min={0} max={2} value={activeTab} onChange={changeActiveTabIndex} />
25
- </div>
26
-
27
- <div>
28
- Lazy render tab panel content:
29
- <input type="checkbox" checked={isLazy} onChange={changeIsLazy} />
30
- </div>
31
-
32
- <div>
33
- Activate tab on focus:
34
- <input type="checkbox" checked={shouldActivateOnFocus} onChange={changeShouldActivateOnFocus} />
35
- </div>
36
- <TabProvider
37
- activeTabIndex={activeTab}
38
- onChange={setActiveTab}
39
- isLazy={isLazy}
40
- shouldActivateOnFocus={shouldActivateOnFocus}
41
- >
42
- <TabList theme={theme} aria-label="Tab list">
43
- <Tab label="Tab a" />
44
- <Tab label="Tab b" />
45
- <Tab label="Tab c" />
46
- </TabList>
47
-
48
- <TabPanel className="lumx-spacing-padding-huge">Tab a content</TabPanel>
49
- <TabPanel className="lumx-spacing-padding-huge">Tab b content</TabPanel>
50
- <TabPanel className="lumx-spacing-padding-huge">Tab c content</TabPanel>
51
- </TabProvider>
52
- </>
53
- );
54
- };
55
-
56
- /* Control active tab internally (with activate tab on focus). */
57
- export const NotControlled = ({ theme }: any) => {
58
- return (
59
- <TabProvider shouldActivateOnFocus onChange={console.log}>
60
- <TabList theme={theme} aria-label="Tab list">
61
- <Tab label="Tab a" />
62
- <Tab label="Tab b" />
63
- </TabList>
64
- <TabPanel className="lumx-spacing-padding-huge">Tab a content</TabPanel>
65
- <TabPanel className="lumx-spacing-padding-huge">Tab b content</TabPanel>
66
- </TabProvider>
67
- );
68
- };
69
-
70
- /* Display tabs far from their tab panels. */
71
- export const DisabledTab = ({ theme }: any) => (
72
- <TabProvider shouldActivateOnFocus>
73
- <TabList theme={theme} aria-label="Tab list">
74
- <Tab label="Tab 1" />
75
- <Tab label="Tab 2" isDisabled />
76
- <Tab label="Tab 3" />
77
- </TabList>
78
- <TabPanel className="lumx-spacing-padding-huge">Tab 1 content</TabPanel>
79
- <TabPanel className="lumx-spacing-padding-huge">Tab 2 content</TabPanel>
80
- <TabPanel className="lumx-spacing-padding-huge">Tab 3 content</TabPanel>
81
- </TabProvider>
82
- );
83
-
84
- /* Display tabs far from their tab panels. */
85
- export const SplitTabListAndTabPanels = ({ theme }: any) => {
86
- const [isOpen, setOpen] = useState(true);
87
- const [activeTabIndex, onChange] = useState(1);
88
-
89
- return (
90
- <TabProvider activeTabIndex={activeTabIndex} onChange={onChange} isLazy={false}>
91
- <Button
92
- onClick={() => {
93
- setOpen(!isOpen);
94
- onChange(1);
95
- }}
96
- >
97
- Open dialog with tabs in footer
98
- </Button>
99
- <Dialog isOpen={isOpen} forceFooterDivider onClose={() => setOpen(false)}>
100
- <TabPanel className="lumx-spacing-padding-huge">Tab 1 content</TabPanel>
101
- <TabPanel className="lumx-spacing-padding-huge">Tab 2 content</TabPanel>
102
- <TabPanel className="lumx-spacing-padding-huge">Tab 3 content</TabPanel>
103
-
104
- <footer>
105
- <TabList theme={theme} aria-label="Tab list">
106
- <Tab label="Tab 1" />
107
- <Tab label="Tab 2" />
108
- <Tab label="Tab 3" />
109
- </TabList>
110
- </footer>
111
- </Dialog>
112
- </TabProvider>
113
- );
114
- };
115
-
116
- /* Dynamically generate tabs. */
117
- export const DynamicTabs = ({ theme }: any) => {
118
- const tabCount = number('Tab count', 3);
119
- return (
120
- <TabProvider>
121
- <TabList theme={theme} aria-label="Tab list">
122
- {times(tabCount, (tabNumber) => (
123
- <Tab key={tabNumber} label={`Tab ${tabNumber}`} />
124
- ))}
125
- </TabList>
126
-
127
- {times(tabCount, (tabNumber) => (
128
- <TabPanel key={tabNumber} className="lumx-spacing-padding-huge">
129
- Tab {tabNumber} content
130
- </TabPanel>
131
- ))}
132
- </TabProvider>
133
- );
134
- };
@@ -1,62 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`<Tab> Snapshots and structure should render 1`] = `
4
- <button
5
- aria-controls="tab-panel-1"
6
- aria-selected={false}
7
- className="lumx-tabs__link"
8
- id="tab-1"
9
- onClick={[Function]}
10
- onFocus={[Function]}
11
- onKeyPress={[Function]}
12
- role="tab"
13
- tabIndex={-1}
14
- type="button"
15
- >
16
- <span>
17
- Test Tab Label
18
- </span>
19
- </button>
20
- `;
21
-
22
- exports[`<Tab> Snapshots and structure should render active state 1`] = `
23
- <button
24
- aria-controls="tab-panel-3"
25
- aria-selected={true}
26
- className="lumx-tabs__link lumx-tabs__link--is-active"
27
- id="tab-3"
28
- onClick={[Function]}
29
- onFocus={[Function]}
30
- onKeyPress={[Function]}
31
- role="tab"
32
- tabIndex={0}
33
- type="button"
34
- >
35
- <span>
36
- Test Tab Label
37
- </span>
38
- </button>
39
- `;
40
-
41
- exports[`<Tab> Snapshots and structure should render icon 1`] = `
42
- <button
43
- aria-controls="tab-panel-2"
44
- aria-selected={false}
45
- className="lumx-tabs__link"
46
- id="tab-2"
47
- onClick={[Function]}
48
- onFocus={[Function]}
49
- onKeyPress={[Function]}
50
- role="tab"
51
- tabIndex={-1}
52
- type="button"
53
- >
54
- <Icon
55
- icon="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"
56
- size="xs"
57
- />
58
- <span>
59
- Test Tab Label
60
- </span>
61
- </button>
62
- `;
@@ -1,22 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`<TabList> Snapshots and structure should render correctly 1`] = `
4
- <div
5
- className="lumx-tabs lumx-tabs--layout-fixed lumx-tabs--position-left lumx-tabs--theme-light"
6
- >
7
- <div
8
- aria-label="Tab list"
9
- className="lumx-tabs__links"
10
- role="tablist"
11
- >
12
- <Tab
13
- key="0"
14
- label="Tab 0"
15
- />
16
- <Tab
17
- key="1"
18
- label="Tab 1"
19
- />
20
- </div>
21
- </div>
22
- `;
@@ -1,25 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`<TabPanel> Snapshots and structure should render correctly 1`] = `
4
- <div
5
- aria-labelledby="tab-1"
6
- className="lumx-tab-panel"
7
- id="tab-panel-1"
8
- role="tabpanel"
9
- tabIndex={0}
10
- >
11
- Tab panel content
12
- </div>
13
- `;
14
-
15
- exports[`<TabPanel> Snapshots and structure should render isActive state 1`] = `
16
- <div
17
- aria-labelledby="tab-2"
18
- className="lumx-tab-panel lumx-tab-panel--is-active"
19
- id="tab-panel-2"
20
- role="tabpanel"
21
- tabIndex={0}
22
- >
23
- Tab panel content
24
- </div>
25
- `;
@@ -1,4 +0,0 @@
1
- export * from './TabProvider';
2
- export * from './TabList';
3
- export * from './Tab';
4
- export * from './TabPanel';
@@ -1,116 +0,0 @@
1
- import { Dispatch, createContext, useCallback, useContext, useEffect, useMemo } from 'react';
2
- import { uid } from 'uid';
3
-
4
- type TabType = 'tab' | 'tabPanel';
5
-
6
- export interface State {
7
- isLazy: boolean;
8
- shouldActivateOnFocus: boolean;
9
- activeTabIndex: number;
10
- ids: Record<TabType, string[]>;
11
- }
12
-
13
- export const INIT_STATE: State = {
14
- isLazy: true,
15
- shouldActivateOnFocus: false,
16
- activeTabIndex: 0,
17
- ids: { tab: [], tabPanel: [] },
18
- };
19
-
20
- export type Action =
21
- | { type: 'update'; payload: Partial<State> }
22
- | { type: 'setActiveTabIndex'; payload: number }
23
- | { type: 'register'; payload: { type: TabType; id: string } }
24
- | { type: 'unregister'; payload: { type: TabType; id: string } };
25
-
26
- export const reducer = (state: State, action: Action): State => {
27
- switch (action.type) {
28
- case 'update':
29
- return { ...state, ...action.payload };
30
- case 'setActiveTabIndex': {
31
- if (state.activeTabIndex === action.payload) {
32
- return state;
33
- }
34
- // Change active tab index.
35
- return { ...state, activeTabIndex: action.payload };
36
- }
37
- case 'register': {
38
- const { type, id } = action.payload;
39
- // Append tab/tabPanel id in state.
40
- return { ...state, ids: { ...state.ids, [type]: [...state.ids[type], id] } };
41
- }
42
- case 'unregister': {
43
- const { type, id } = action.payload;
44
- const index = state.ids[type].indexOf(id);
45
- if (index === -1) return state;
46
- // Remove tab & tab panel at index.
47
- const tabIds = [...state.ids.tab];
48
- tabIds.splice(index, 1);
49
- const tabPanelIds = [...state.ids.tabPanel];
50
- tabPanelIds.splice(index, 1);
51
- return {
52
- ...state,
53
- ids: { tab: tabIds, tabPanel: tabPanelIds },
54
- };
55
- }
56
- default:
57
- return state;
58
- }
59
- };
60
-
61
- export const TabProviderContext = createContext<[State, Dispatch<Action>] | null>(null);
62
-
63
- export type TabState = Pick<Required<State>, 'isLazy' | 'shouldActivateOnFocus'> & {
64
- isActive: boolean;
65
- tabId: string;
66
- tabPanelId: string;
67
- changeToTab(): void;
68
- };
69
-
70
- /* eslint-disable react-hooks/rules-of-hooks */
71
- export const useTabProviderContext = (type: TabType, originalId?: string): undefined | TabState => {
72
- const context = useContext(TabProviderContext);
73
- if (!context) {
74
- return undefined;
75
- }
76
- const [state, dispatch] = context;
77
-
78
- // Current tab or tab panel id.
79
- const id = useMemo(
80
- () => originalId || `${type}-${uid()}`,
81
- // eslint-disable-next-line react-hooks/exhaustive-deps
82
- [],
83
- );
84
- useEffect(
85
- () => {
86
- // On mount: register tab or tab panel id.
87
- dispatch({ type: 'register', payload: { type, id } });
88
- return () => {
89
- // On unmount: unregister tab or tab panel id.
90
- dispatch({ type: 'unregister', payload: { type, id } });
91
- };
92
- },
93
- // eslint-disable-next-line react-hooks/exhaustive-deps
94
- [],
95
- );
96
-
97
- // Find tab/tabPanel index using it's id.
98
- const index = useMemo(() => state.ids[type].indexOf(id), [state.ids, type, id]);
99
- const tabId = useMemo(() => state.ids.tab[index] || '', [state, index]);
100
- const tabPanelId = useMemo(() => state.ids.tabPanel[index] || '', [state, index]);
101
- const isActive = useMemo(() => state.activeTabIndex === index, [state, index]);
102
- const changeToTab = useCallback(() => dispatch({ type: 'setActiveTabIndex', payload: index }), [dispatch, index]);
103
- return {
104
- isLazy: state.isLazy,
105
- shouldActivateOnFocus: state.shouldActivateOnFocus,
106
- tabId,
107
- tabPanelId,
108
- isActive,
109
- changeToTab,
110
- };
111
- };
112
-
113
- export const useTabProviderContextState = (): State | undefined => {
114
- const context = useContext(TabProviderContext);
115
- return context?.[0];
116
- };
@@ -1,33 +0,0 @@
1
- import { TabState, useTabProviderContext, useTabProviderContextState } from './state';
2
-
3
- export function setupTabProviderMocks(options: any = {}) {
4
- const changeToTab = jest.fn();
5
- const mockedHook = jest.fn(
6
- (): TabState => {
7
- const index = options.index || 0;
8
- const isLazy = options.isLazy as any;
9
- const shouldActivateOnFocus = options.shouldActivateOnFocus as any;
10
- const isActive = options.isActive || false;
11
- return {
12
- isLazy,
13
- shouldActivateOnFocus,
14
- changeToTab,
15
- tabId: `tab-${index}`,
16
- tabPanelId: `tab-panel-${index}`,
17
- isActive,
18
- };
19
- },
20
- );
21
- (useTabProviderContext as jest.Mock).mockImplementationOnce(mockedHook);
22
-
23
- const mockedHook2 = jest.fn((): any => {
24
- const index = options.index || 0;
25
- const numberOfSteps = options.numberOfSteps || 2;
26
- return {
27
- ids: { tab: { length: numberOfSteps } },
28
- activeTabIndex: index,
29
- };
30
- });
31
- (useTabProviderContextState as jest.Mock).mockImplementationOnce(mockedHook2);
32
- return { mockedHook, changeToTab };
33
- }