@lumx/react 3.1.1 → 3.1.3-alpha.0

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