@lumx/react 3.1.0 → 3.1.2

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