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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (502) hide show
  1. package/{dist/CONTRIBUTING.md → CONTRIBUTING.md} +0 -0
  2. package/{dist/LICENSE.md → LICENSE.md} +0 -0
  3. package/{dist/_internal → _internal}/ClickAwayProvider.js +0 -0
  4. package/{dist/_internal → _internal}/ClickAwayProvider.js.map +0 -0
  5. package/{dist/_internal → _internal}/types.d.ts +1 -1
  6. package/{dist/index.d.ts → index.d.ts} +7 -7
  7. package/{dist/index.js → index.js} +0 -0
  8. package/{dist/index.js.map → index.js.map} +1 -1
  9. package/package.json +3 -3
  10. package/src/components/badge/Badge.tsx +2 -2
  11. package/src/components/button/ButtonRoot.tsx +2 -2
  12. package/src/components/chip/Chip.tsx +2 -2
  13. package/src/components/icon/Icon.tsx +2 -2
  14. package/src/components/link/Link.tsx +2 -2
  15. package/{dist/utils → utils}/index.d.ts +0 -0
  16. package/{dist/utils → utils}/index.js +0 -0
  17. package/{dist/utils → utils}/index.js.map +0 -0
  18. package/dist/README.md +0 -38
  19. package/dist/package.json +0 -117
  20. package/dist/src/components/alert-dialog/AlertDialog.stories.tsx +0 -196
  21. package/dist/src/components/alert-dialog/AlertDialog.test.tsx +0 -43
  22. package/dist/src/components/alert-dialog/AlertDialog.tsx +0 -185
  23. package/dist/src/components/alert-dialog/__snapshots__/AlertDialog.test.tsx.snap +0 -551
  24. package/dist/src/components/alert-dialog/index.ts +0 -1
  25. package/dist/src/components/autocomplete/Autocomplete.stories.tsx +0 -70
  26. package/dist/src/components/autocomplete/Autocomplete.test.tsx +0 -181
  27. package/dist/src/components/autocomplete/Autocomplete.tsx +0 -292
  28. package/dist/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -170
  29. package/dist/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -94
  30. package/dist/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
  31. package/dist/src/components/autocomplete/__mockData__/index.ts +0 -34
  32. package/dist/src/components/autocomplete/__snapshots__/Autocomplete.test.tsx.snap +0 -213
  33. package/dist/src/components/autocomplete/__snapshots__/AutocompleteMultiple.test.tsx.snap +0 -88
  34. package/dist/src/components/autocomplete/index.ts +0 -2
  35. package/dist/src/components/avatar/Avatar.stories.tsx +0 -92
  36. package/dist/src/components/avatar/Avatar.test.tsx +0 -39
  37. package/dist/src/components/avatar/Avatar.tsx +0 -112
  38. package/dist/src/components/avatar/__snapshots__/Avatar.test.tsx.snap +0 -681
  39. package/dist/src/components/avatar/index.ts +0 -1
  40. package/dist/src/components/badge/Badge.stories.tsx +0 -45
  41. package/dist/src/components/badge/Badge.test.tsx +0 -91
  42. package/dist/src/components/badge/Badge.tsx +0 -55
  43. package/dist/src/components/badge/__snapshots__/Badge.test.tsx.snap +0 -11
  44. package/dist/src/components/badge/index.ts +0 -1
  45. package/dist/src/components/button/Button.stories.tsx +0 -156
  46. package/dist/src/components/button/Button.test.tsx +0 -152
  47. package/dist/src/components/button/Button.tsx +0 -81
  48. package/dist/src/components/button/ButtonGroup.test.tsx +0 -66
  49. package/dist/src/components/button/ButtonGroup.tsx +0 -46
  50. package/dist/src/components/button/ButtonRoot.test.tsx +0 -203
  51. package/dist/src/components/button/ButtonRoot.tsx +0 -190
  52. package/dist/src/components/button/IconButton.test.tsx +0 -103
  53. package/dist/src/components/button/IconButton.tsx +0 -80
  54. package/dist/src/components/button/__snapshots__/Button.test.tsx.snap +0 -96
  55. package/dist/src/components/button/__snapshots__/ButtonGroup.test.tsx.snap +0 -22
  56. package/dist/src/components/button/__snapshots__/ButtonRoot.test.tsx.snap +0 -160
  57. package/dist/src/components/button/__snapshots__/IconButton.test.tsx.snap +0 -83
  58. package/dist/src/components/button/index.ts +0 -4
  59. package/dist/src/components/checkbox/Checkbox.stories.tsx +0 -37
  60. package/dist/src/components/checkbox/Checkbox.test.tsx +0 -114
  61. package/dist/src/components/checkbox/Checkbox.tsx +0 -145
  62. package/dist/src/components/checkbox/__snapshots__/Checkbox.test.tsx.snap +0 -141
  63. package/dist/src/components/checkbox/index.ts +0 -1
  64. package/dist/src/components/chip/Chip.stories.tsx +0 -21
  65. package/dist/src/components/chip/Chip.test.tsx +0 -199
  66. package/dist/src/components/chip/Chip.tsx +0 -154
  67. package/dist/src/components/chip/ChipGroup.test.tsx +0 -29
  68. package/dist/src/components/chip/ChipGroup.tsx +0 -62
  69. package/dist/src/components/chip/__snapshots__/Chip.test.tsx.snap +0 -12
  70. package/dist/src/components/chip/__snapshots__/ChipGroup.test.tsx.snap +0 -29
  71. package/dist/src/components/chip/index.ts +0 -2
  72. package/dist/src/components/comment-block/CommentBlock.stories.tsx +0 -30
  73. package/dist/src/components/comment-block/CommentBlock.test.tsx +0 -28
  74. package/dist/src/components/comment-block/CommentBlock.tsx +0 -174
  75. package/dist/src/components/comment-block/__snapshots__/CommentBlock.test.tsx.snap +0 -92
  76. package/dist/src/components/comment-block/index.ts +0 -1
  77. package/dist/src/components/date-picker/DatePicker.test.tsx +0 -41
  78. package/dist/src/components/date-picker/DatePicker.tsx +0 -56
  79. package/dist/src/components/date-picker/DatePickerControlled.test.tsx +0 -44
  80. package/dist/src/components/date-picker/DatePickerControlled.tsx +0 -128
  81. package/dist/src/components/date-picker/DatePickerField.stories.tsx +0 -93
  82. package/dist/src/components/date-picker/DatePickerField.test.tsx +0 -47
  83. package/dist/src/components/date-picker/DatePickerField.tsx +0 -141
  84. package/dist/src/components/date-picker/__snapshots__/DatePicker.test.tsx.snap +0 -22
  85. package/dist/src/components/date-picker/__snapshots__/DatePickerControlled.test.tsx.snap +0 -597
  86. package/dist/src/components/date-picker/__snapshots__/DatePickerField.test.tsx.snap +0 -43
  87. package/dist/src/components/date-picker/constants.ts +0 -11
  88. package/dist/src/components/date-picker/index.ts +0 -4
  89. package/dist/src/components/date-picker/types.ts +0 -28
  90. package/dist/src/components/dialog/Dialog.stories.tsx +0 -426
  91. package/dist/src/components/dialog/Dialog.test.tsx +0 -93
  92. package/dist/src/components/dialog/Dialog.tsx +0 -263
  93. package/dist/src/components/dialog/__snapshots__/Dialog.test.tsx.snap +0 -960
  94. package/dist/src/components/dialog/index.ts +0 -1
  95. package/dist/src/components/divider/Divider.test.tsx +0 -93
  96. package/dist/src/components/divider/Divider.tsx +0 -51
  97. package/dist/src/components/divider/__snapshots__/Divider.test.tsx.snap +0 -9
  98. package/dist/src/components/divider/index.ts +0 -1
  99. package/dist/src/components/drag-handle/DragHandle.tsx +0 -50
  100. package/dist/src/components/drag-handle/index.ts +0 -1
  101. package/dist/src/components/dropdown/Dropdown.stories.tsx +0 -216
  102. package/dist/src/components/dropdown/Dropdown.test.tsx +0 -97
  103. package/dist/src/components/dropdown/Dropdown.tsx +0 -184
  104. package/dist/src/components/dropdown/__snapshots__/Dropdown.test.tsx.snap +0 -35
  105. package/dist/src/components/dropdown/index.ts +0 -1
  106. package/dist/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -116
  107. package/dist/src/components/expansion-panel/ExpansionPanel.tsx +0 -170
  108. package/dist/src/components/expansion-panel/index.ts +0 -1
  109. package/dist/src/components/flag/Flag.stories.tsx +0 -23
  110. package/dist/src/components/flag/Flag.test.tsx +0 -86
  111. package/dist/src/components/flag/Flag.tsx +0 -47
  112. package/dist/src/components/flag/__snapshots__/Flag.test.tsx.snap +0 -133
  113. package/dist/src/components/flag/index.ts +0 -1
  114. package/dist/src/components/flex-box/FlexBox.stories.tsx +0 -245
  115. package/dist/src/components/flex-box/FlexBox.test.tsx +0 -65
  116. package/dist/src/components/flex-box/FlexBox.tsx +0 -98
  117. package/dist/src/components/flex-box/__snapshots__/FlexBox.test.tsx.snap +0 -492
  118. package/dist/src/components/flex-box/index.ts +0 -1
  119. package/dist/src/components/generic-block/GenericBlock.stories.jsx +0 -128
  120. package/dist/src/components/generic-block/GenericBlock.test.tsx +0 -152
  121. package/dist/src/components/generic-block/GenericBlock.tsx +0 -222
  122. package/dist/src/components/generic-block/constants.ts +0 -9
  123. package/dist/src/components/generic-block/index.ts +0 -2
  124. package/dist/src/components/grid/Grid.tsx +0 -73
  125. package/dist/src/components/grid/GridItem.tsx +0 -54
  126. package/dist/src/components/grid/index.ts +0 -2
  127. package/dist/src/components/grid-column/GridColumn.stories.jsx +0 -56
  128. package/dist/src/components/grid-column/GridColumn.test.jsx +0 -58
  129. package/dist/src/components/grid-column/GridColumn.tsx +0 -90
  130. package/dist/src/components/grid-column/index.ts +0 -1
  131. package/dist/src/components/heading/Heading.stories.tsx +0 -108
  132. package/dist/src/components/heading/Heading.test.tsx +0 -82
  133. package/dist/src/components/heading/Heading.tsx +0 -63
  134. package/dist/src/components/heading/HeadingLevelProvider.tsx +0 -30
  135. package/dist/src/components/heading/constants.ts +0 -16
  136. package/dist/src/components/heading/context.tsx +0 -13
  137. package/dist/src/components/heading/index.ts +0 -3
  138. package/dist/src/components/heading/useHeadingLevel.tsx +0 -8
  139. package/dist/src/components/icon/Icon.stories.tsx +0 -76
  140. package/dist/src/components/icon/Icon.test.tsx +0 -102
  141. package/dist/src/components/icon/Icon.tsx +0 -121
  142. package/dist/src/components/icon/__snapshots__/Icon.test.tsx.snap +0 -49
  143. package/dist/src/components/icon/index.ts +0 -1
  144. package/dist/src/components/image-block/ImageBlock.stories.tsx +0 -52
  145. package/dist/src/components/image-block/ImageBlock.test.tsx +0 -28
  146. package/dist/src/components/image-block/ImageBlock.tsx +0 -151
  147. package/dist/src/components/image-block/__snapshots__/ImageBlock.test.tsx.snap +0 -64
  148. package/dist/src/components/image-block/index.ts +0 -1
  149. package/dist/src/components/index.ts +0 -176
  150. package/dist/src/components/inline-list/InlineList.stories.tsx +0 -40
  151. package/dist/src/components/inline-list/InlineList.test.tsx +0 -41
  152. package/dist/src/components/inline-list/InlineList.tsx +0 -82
  153. package/dist/src/components/inline-list/index.ts +0 -1
  154. package/dist/src/components/input-helper/InputHelper.stories.tsx +0 -29
  155. package/dist/src/components/input-helper/InputHelper.test.tsx +0 -107
  156. package/dist/src/components/input-helper/InputHelper.tsx +0 -61
  157. package/dist/src/components/input-helper/__snapshots__/InputHelper.test.tsx.snap +0 -9
  158. package/dist/src/components/input-helper/constants.ts +0 -11
  159. package/dist/src/components/input-helper/index.ts +0 -1
  160. package/dist/src/components/input-label/InputLabel.stories.tsx +0 -15
  161. package/dist/src/components/input-label/InputLabel.test.tsx +0 -86
  162. package/dist/src/components/input-label/InputLabel.tsx +0 -59
  163. package/dist/src/components/input-label/__snapshots__/InputLabel.test.tsx.snap +0 -10
  164. package/dist/src/components/input-label/index.ts +0 -1
  165. package/dist/src/components/lightbox/Lightbox.stories.tsx +0 -83
  166. package/dist/src/components/lightbox/Lightbox.test.tsx +0 -30
  167. package/dist/src/components/lightbox/Lightbox.tsx +0 -153
  168. package/dist/src/components/lightbox/__snapshots__/Lightbox.test.tsx.snap +0 -194
  169. package/dist/src/components/lightbox/index.ts +0 -1
  170. package/dist/src/components/link/Link.stories.tsx +0 -141
  171. package/dist/src/components/link/Link.test.tsx +0 -60
  172. package/dist/src/components/link/Link.tsx +0 -156
  173. package/dist/src/components/link/__snapshots__/Link.test.tsx.snap +0 -29
  174. package/dist/src/components/link/index.ts +0 -1
  175. package/dist/src/components/link-preview/LinkPreview.stories.tsx +0 -88
  176. package/dist/src/components/link-preview/LinkPreview.test.tsx +0 -102
  177. package/dist/src/components/link-preview/LinkPreview.tsx +0 -158
  178. package/dist/src/components/link-preview/index.ts +0 -1
  179. package/dist/src/components/list/List.stories.tsx +0 -141
  180. package/dist/src/components/list/List.test.tsx +0 -29
  181. package/dist/src/components/list/List.tsx +0 -94
  182. package/dist/src/components/list/ListDivider.stories.tsx +0 -7
  183. package/dist/src/components/list/ListDivider.test.tsx +0 -29
  184. package/dist/src/components/list/ListDivider.tsx +0 -42
  185. package/dist/src/components/list/ListItem.stories.tsx +0 -62
  186. package/dist/src/components/list/ListItem.test.tsx +0 -29
  187. package/dist/src/components/list/ListItem.tsx +0 -154
  188. package/dist/src/components/list/ListSubheader.stories.tsx +0 -8
  189. package/dist/src/components/list/ListSubheader.test.tsx +0 -29
  190. package/dist/src/components/list/ListSubheader.tsx +0 -43
  191. package/dist/src/components/list/__snapshots__/List.test.tsx.snap +0 -360
  192. package/dist/src/components/list/__snapshots__/ListDivider.test.tsx.snap +0 -7
  193. package/dist/src/components/list/__snapshots__/ListItem.test.tsx.snap +0 -160
  194. package/dist/src/components/list/__snapshots__/ListSubheader.test.tsx.snap +0 -9
  195. package/dist/src/components/list/index.ts +0 -4
  196. package/dist/src/components/list/useInteractiveList.tsx +0 -202
  197. package/dist/src/components/message/Message.stories.tsx +0 -27
  198. package/dist/src/components/message/Message.test.tsx +0 -76
  199. package/dist/src/components/message/Message.tsx +0 -74
  200. package/dist/src/components/message/__snapshots__/Message.test.tsx.snap +0 -15
  201. package/dist/src/components/message/index.ts +0 -1
  202. package/dist/src/components/mosaic/Mosaic.stories.tsx +0 -85
  203. package/dist/src/components/mosaic/Mosaic.test.tsx +0 -120
  204. package/dist/src/components/mosaic/Mosaic.tsx +0 -95
  205. package/dist/src/components/mosaic/__snapshots__/Mosaic.test.tsx.snap +0 -357
  206. package/dist/src/components/mosaic/index.ts +0 -1
  207. package/dist/src/components/notification/Notification.test.tsx +0 -108
  208. package/dist/src/components/notification/Notification.tsx +0 -130
  209. package/dist/src/components/notification/Notifications.stories.tsx +0 -77
  210. package/dist/src/components/notification/__snapshots__/Notification.test.tsx.snap +0 -34
  211. package/dist/src/components/notification/constants.ts +0 -28
  212. package/dist/src/components/notification/index.ts +0 -1
  213. package/dist/src/components/popover/Popover.stories.tsx +0 -386
  214. package/dist/src/components/popover/Popover.test.tsx +0 -30
  215. package/dist/src/components/popover/Popover.tsx +0 -382
  216. package/dist/src/components/popover/__snapshots__/Popover.test.tsx.snap +0 -343
  217. package/dist/src/components/popover/index.ts +0 -1
  218. package/dist/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -75
  219. package/dist/src/components/popover-dialog/PopoverDialog.test.tsx +0 -65
  220. package/dist/src/components/popover-dialog/PopoverDialog.tsx +0 -65
  221. package/dist/src/components/popover-dialog/index.tsx +0 -1
  222. package/dist/src/components/post-block/PostBlock.test.tsx +0 -28
  223. package/dist/src/components/post-block/PostBlock.tsx +0 -123
  224. package/dist/src/components/post-block/__snapshots__/PostBlock.test.tsx.snap +0 -139
  225. package/dist/src/components/post-block/index.ts +0 -1
  226. package/dist/src/components/progress/Progress.tsx +0 -68
  227. package/dist/src/components/progress/ProgressCircular.stories.tsx +0 -18
  228. package/dist/src/components/progress/ProgressCircular.test.tsx +0 -49
  229. package/dist/src/components/progress/ProgressCircular.tsx +0 -68
  230. package/dist/src/components/progress/ProgressLinear.stories.tsx +0 -8
  231. package/dist/src/components/progress/ProgressLinear.test.tsx +0 -37
  232. package/dist/src/components/progress/ProgressLinear.tsx +0 -52
  233. package/dist/src/components/progress/index.ts +0 -3
  234. package/dist/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
  235. package/dist/src/components/progress-tracker/ProgressTracker.test.tsx +0 -57
  236. package/dist/src/components/progress-tracker/ProgressTracker.tsx +0 -89
  237. package/dist/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -42
  238. package/dist/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -66
  239. package/dist/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -128
  240. package/dist/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
  241. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -73
  242. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -67
  243. package/dist/src/components/progress-tracker/__snapshots__/ProgressTracker.test.tsx.snap +0 -41
  244. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStep.test.tsx.snap +0 -141
  245. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStepPanel.test.tsx.snap +0 -25
  246. package/dist/src/components/progress-tracker/index.ts +0 -4
  247. package/dist/src/components/radio-button/RadioButton.stories.tsx +0 -28
  248. package/dist/src/components/radio-button/RadioButton.test.tsx +0 -123
  249. package/dist/src/components/radio-button/RadioButton.tsx +0 -141
  250. package/dist/src/components/radio-button/RadioGroup.stories.tsx +0 -42
  251. package/dist/src/components/radio-button/RadioGroup.test.tsx +0 -77
  252. package/dist/src/components/radio-button/RadioGroup.tsx +0 -52
  253. package/dist/src/components/radio-button/__snapshots__/RadioButton.test.tsx.snap +0 -113
  254. package/dist/src/components/radio-button/__snapshots__/RadioGroup.test.tsx.snap +0 -26
  255. package/dist/src/components/radio-button/index.ts +0 -2
  256. package/dist/src/components/select/Select.stories.tsx +0 -399
  257. package/dist/src/components/select/Select.test.tsx +0 -359
  258. package/dist/src/components/select/Select.tsx +0 -193
  259. package/dist/src/components/select/SelectMultiple.stories.tsx +0 -227
  260. package/dist/src/components/select/SelectMultiple.test.tsx +0 -405
  261. package/dist/src/components/select/SelectMultiple.tsx +0 -198
  262. package/dist/src/components/select/WithSelectContext.tsx +0 -143
  263. package/dist/src/components/select/__snapshots__/Select.test.tsx.snap +0 -43
  264. package/dist/src/components/select/__snapshots__/SelectMultiple.test.tsx.snap +0 -87
  265. package/dist/src/components/select/constants.ts +0 -53
  266. package/dist/src/components/select/index.ts +0 -2
  267. package/dist/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
  268. package/dist/src/components/side-navigation/SideNavigation.test.tsx +0 -52
  269. package/dist/src/components/side-navigation/SideNavigation.tsx +0 -54
  270. package/dist/src/components/side-navigation/SideNavigationItem.test.tsx +0 -175
  271. package/dist/src/components/side-navigation/SideNavigationItem.tsx +0 -162
  272. package/dist/src/components/side-navigation/__snapshots__/SideNavigation.test.tsx.snap +0 -7
  273. package/dist/src/components/side-navigation/__snapshots__/SideNavigationItem.test.tsx.snap +0 -30
  274. package/dist/src/components/side-navigation/index.ts +0 -2
  275. package/dist/src/components/skeleton/SkeletonCircle.stories.tsx +0 -25
  276. package/dist/src/components/skeleton/SkeletonCircle.test.tsx +0 -28
  277. package/dist/src/components/skeleton/SkeletonCircle.tsx +0 -52
  278. package/dist/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -107
  279. package/dist/src/components/skeleton/SkeletonRectangle.test.tsx +0 -28
  280. package/dist/src/components/skeleton/SkeletonRectangle.tsx +0 -78
  281. package/dist/src/components/skeleton/SkeletonTypography.stories.tsx +0 -26
  282. package/dist/src/components/skeleton/SkeletonTypography.test.tsx +0 -28
  283. package/dist/src/components/skeleton/SkeletonTypography.tsx +0 -57
  284. package/dist/src/components/skeleton/__snapshots__/SkeletonCircle.test.tsx.snap +0 -54
  285. package/dist/src/components/skeleton/__snapshots__/SkeletonRectangle.test.tsx.snap +0 -177
  286. package/dist/src/components/skeleton/__snapshots__/SkeletonTypography.test.tsx.snap +0 -174
  287. package/dist/src/components/skeleton/index.ts +0 -3
  288. package/dist/src/components/slider/Slider.stories.tsx +0 -29
  289. package/dist/src/components/slider/Slider.test.tsx +0 -31
  290. package/dist/src/components/slider/Slider.tsx +0 -299
  291. package/dist/src/components/slider/__snapshots__/Slider.test.tsx.snap +0 -122
  292. package/dist/src/components/slider/index.ts +0 -2
  293. package/dist/src/components/slideshow/Slides.tsx +0 -124
  294. package/dist/src/components/slideshow/Slideshow.stories.tsx +0 -212
  295. package/dist/src/components/slideshow/Slideshow.test.tsx +0 -39
  296. package/dist/src/components/slideshow/Slideshow.tsx +0 -170
  297. package/dist/src/components/slideshow/SlideshowControls.stories.tsx +0 -112
  298. package/dist/src/components/slideshow/SlideshowControls.tsx +0 -241
  299. package/dist/src/components/slideshow/SlideshowItem.tsx +0 -52
  300. package/dist/src/components/slideshow/SlideshowItemGroup.tsx +0 -64
  301. package/dist/src/components/slideshow/__snapshots__/Slideshow.test.tsx.snap +0 -157
  302. package/dist/src/components/slideshow/constants.ts +0 -24
  303. package/dist/src/components/slideshow/index.ts +0 -4
  304. package/dist/src/components/slideshow/useKeyNavigate.ts +0 -28
  305. package/dist/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
  306. package/dist/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
  307. package/dist/src/components/slideshow/useSwipeNavigate.ts +0 -18
  308. package/dist/src/components/switch/Switch.stories.tsx +0 -36
  309. package/dist/src/components/switch/Switch.test.tsx +0 -189
  310. package/dist/src/components/switch/Switch.tsx +0 -141
  311. package/dist/src/components/switch/__snapshots__/Switch.test.tsx.snap +0 -179
  312. package/dist/src/components/switch/index.ts +0 -1
  313. package/dist/src/components/table/Table.test.tsx +0 -28
  314. package/dist/src/components/table/Table.tsx +0 -59
  315. package/dist/src/components/table/TableBody.test.tsx +0 -22
  316. package/dist/src/components/table/TableBody.tsx +0 -44
  317. package/dist/src/components/table/TableCell.test.tsx +0 -23
  318. package/dist/src/components/table/TableCell.tsx +0 -125
  319. package/dist/src/components/table/TableHeader.test.tsx +0 -22
  320. package/dist/src/components/table/TableHeader.tsx +0 -50
  321. package/dist/src/components/table/TableRow.test.tsx +0 -22
  322. package/dist/src/components/table/TableRow.tsx +0 -68
  323. package/dist/src/components/table/__snapshots__/Table.test.tsx.snap +0 -263
  324. package/dist/src/components/table/index.ts +0 -5
  325. package/dist/src/components/tabs/Tab.test.tsx +0 -116
  326. package/dist/src/components/tabs/Tab.tsx +0 -120
  327. package/dist/src/components/tabs/TabList.test.tsx +0 -80
  328. package/dist/src/components/tabs/TabList.tsx +0 -82
  329. package/dist/src/components/tabs/TabPanel.test.tsx +0 -74
  330. package/dist/src/components/tabs/TabPanel.tsx +0 -65
  331. package/dist/src/components/tabs/TabProvider.test.tsx +0 -42
  332. package/dist/src/components/tabs/TabProvider.tsx +0 -59
  333. package/dist/src/components/tabs/Tabs.stories.tsx +0 -134
  334. package/dist/src/components/tabs/__snapshots__/Tab.test.tsx.snap +0 -62
  335. package/dist/src/components/tabs/__snapshots__/TabList.test.tsx.snap +0 -22
  336. package/dist/src/components/tabs/__snapshots__/TabPanel.test.tsx.snap +0 -25
  337. package/dist/src/components/tabs/index.ts +0 -4
  338. package/dist/src/components/tabs/state.ts +0 -116
  339. package/dist/src/components/tabs/test.mocks.ts +0 -33
  340. package/dist/src/components/text/Text.stories.jsx +0 -75
  341. package/dist/src/components/text/Text.test.tsx +0 -108
  342. package/dist/src/components/text/Text.tsx +0 -121
  343. package/dist/src/components/text/index.ts +0 -1
  344. package/dist/src/components/text-field/TextField.stories.tsx +0 -169
  345. package/dist/src/components/text-field/TextField.test.tsx +0 -171
  346. package/dist/src/components/text-field/TextField.tsx +0 -432
  347. package/dist/src/components/text-field/__snapshots__/TextField.test.tsx.snap +0 -42
  348. package/dist/src/components/text-field/index.ts +0 -1
  349. package/dist/src/components/thumbnail/Thumbnail.stories.tsx +0 -510
  350. package/dist/src/components/thumbnail/Thumbnail.test.tsx +0 -46
  351. package/dist/src/components/thumbnail/Thumbnail.tsx +0 -222
  352. package/dist/src/components/thumbnail/__snapshots__/Thumbnail.test.tsx.snap +0 -130
  353. package/dist/src/components/thumbnail/index.ts +0 -3
  354. package/dist/src/components/thumbnail/types.ts +0 -39
  355. package/dist/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
  356. package/dist/src/components/thumbnail/useFocusPointStyle.tsx +0 -111
  357. package/dist/src/components/thumbnail/useImageLoad.ts +0 -40
  358. package/dist/src/components/toolbar/Toolbar.tsx +0 -67
  359. package/dist/src/components/toolbar/index.ts +0 -1
  360. package/dist/src/components/tooltip/Tooltip.stories.tsx +0 -172
  361. package/dist/src/components/tooltip/Tooltip.test.tsx +0 -105
  362. package/dist/src/components/tooltip/Tooltip.tsx +0 -122
  363. package/dist/src/components/tooltip/__snapshots__/Tooltip.test.tsx.snap +0 -233
  364. package/dist/src/components/tooltip/index.ts +0 -1
  365. package/dist/src/components/tooltip/useInjectTooltipRef.tsx +0 -44
  366. package/dist/src/components/tooltip/useTooltipOpen.tsx +0 -113
  367. package/dist/src/components/uploader/Uploader.test.tsx +0 -87
  368. package/dist/src/components/uploader/Uploader.tsx +0 -105
  369. package/dist/src/components/uploader/__snapshots__/Uploader.test.tsx.snap +0 -14
  370. package/dist/src/components/uploader/index.ts +0 -1
  371. package/dist/src/components/user-block/UserBlock.stories.tsx +0 -76
  372. package/dist/src/components/user-block/UserBlock.test.tsx +0 -38
  373. package/dist/src/components/user-block/UserBlock.tsx +0 -179
  374. package/dist/src/components/user-block/__snapshots__/UserBlock.test.tsx.snap +0 -362
  375. package/dist/src/components/user-block/index.ts +0 -1
  376. package/dist/src/constants.ts +0 -17
  377. package/dist/src/hooks/useBooleanState.tsx +0 -13
  378. package/dist/src/hooks/useCallbackOnEscape.ts +0 -34
  379. package/dist/src/hooks/useChipGroupNavigation.tsx +0 -75
  380. package/dist/src/hooks/useClickAway.tsx +0 -47
  381. package/dist/src/hooks/useDisableBodyScroll.ts +0 -28
  382. package/dist/src/hooks/useEventCallback.tsx +0 -17
  383. package/dist/src/hooks/useFocus.tsx +0 -21
  384. package/dist/src/hooks/useFocusTrap.ts +0 -85
  385. package/dist/src/hooks/useFocusWithin.ts +0 -33
  386. package/dist/src/hooks/useInfiniteScroll.tsx +0 -60
  387. package/dist/src/hooks/useIntersectionObserver.tsx +0 -43
  388. package/dist/src/hooks/useInterval.tsx +0 -31
  389. package/dist/src/hooks/useKeyboardListNavigation.tsx +0 -204
  390. package/dist/src/hooks/useListenFocus.tsx +0 -26
  391. package/dist/src/hooks/useOnResize.ts +0 -41
  392. package/dist/src/hooks/useRovingTabIndex.tsx +0 -90
  393. package/dist/src/hooks/useSlideshowControls.ts +0 -243
  394. package/dist/src/hooks/useStopPropagation.ts +0 -21
  395. package/dist/src/hooks/useTransitionVisibility.ts +0 -54
  396. package/dist/src/index.ts +0 -58
  397. package/dist/src/stories/chromaticForceScreenSize.tsx +0 -7
  398. package/dist/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
  399. package/dist/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
  400. package/dist/src/stories/generated/Badge/Demos.stories.tsx +0 -9
  401. package/dist/src/stories/generated/Button/Demos.stories.tsx +0 -11
  402. package/dist/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
  403. package/dist/src/stories/generated/Chip/Demos.stories.tsx +0 -11
  404. package/dist/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
  405. package/dist/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
  406. package/dist/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
  407. package/dist/src/stories/generated/Divider/Demos.stories.tsx +0 -6
  408. package/dist/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
  409. package/dist/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
  410. package/dist/src/stories/generated/Flag/Demos.stories.tsx +0 -6
  411. package/dist/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
  412. package/dist/src/stories/generated/Heading/Demos.stories.tsx +0 -6
  413. package/dist/src/stories/generated/Icon/Demos.stories.tsx +0 -8
  414. package/dist/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
  415. package/dist/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
  416. package/dist/src/stories/generated/Link/Demos.stories.tsx +0 -8
  417. package/dist/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
  418. package/dist/src/stories/generated/List/Demos.stories.tsx +0 -11
  419. package/dist/src/stories/generated/Message/Demos.stories.tsx +0 -10
  420. package/dist/src/stories/generated/Mosaic/Demos.stories.tsx +0 -9
  421. package/dist/src/stories/generated/Notification/Demos.stories.tsx +0 -6
  422. package/dist/src/stories/generated/Popover/Demos.stories.tsx +0 -11
  423. package/dist/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
  424. package/dist/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
  425. package/dist/src/stories/generated/Progress/Demos.stories.tsx +0 -7
  426. package/dist/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
  427. package/dist/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
  428. package/dist/src/stories/generated/Select/Demos.stories.tsx +0 -14
  429. package/dist/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
  430. package/dist/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
  431. package/dist/src/stories/generated/Slider/Demos.stories.tsx +0 -9
  432. package/dist/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
  433. package/dist/src/stories/generated/Switch/Demos.stories.tsx +0 -6
  434. package/dist/src/stories/generated/Table/Demos.stories.tsx +0 -6
  435. package/dist/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
  436. package/dist/src/stories/generated/TextField/Demos.stories.tsx +0 -19
  437. package/dist/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
  438. package/dist/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
  439. package/dist/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
  440. package/dist/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
  441. package/dist/src/stories/generated/UserBlock/Demos.stories.tsx +0 -10
  442. package/dist/src/stories/knobs/buttonKnob.ts +0 -9
  443. package/dist/src/stories/knobs/emphasisKnob.ts +0 -8
  444. package/dist/src/stories/knobs/enumKnob.ts +0 -14
  445. package/dist/src/stories/knobs/focusKnob.ts +0 -3
  446. package/dist/src/stories/knobs/image.ts +0 -69
  447. package/dist/src/stories/knobs/lorem.ts +0 -59
  448. package/dist/src/stories/knobs/sizeKnob.ts +0 -5
  449. package/dist/src/stories/knobs/thumbnailsKnob.ts +0 -9
  450. package/dist/src/stories/utils/CustomLink.tsx +0 -7
  451. package/dist/src/stories/withResizableBox.tsx +0 -18
  452. package/dist/src/testing/utils/commonTestsSuite.ts +0 -71
  453. package/dist/src/testing/utils/commonTestsSuiteRTL.ts +0 -55
  454. package/dist/src/testing/utils/index.ts +0 -4
  455. package/dist/src/testing/utils/itShouldRenderStories.tsx +0 -103
  456. package/dist/src/testing/utils/queries.ts +0 -19
  457. package/dist/src/untypped-modules.d.ts +0 -7
  458. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -58
  459. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -65
  460. package/dist/src/utils/ClickAwayProvider/index.ts +0 -1
  461. package/dist/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
  462. package/dist/src/utils/MaterialThemeSwitcher/index.ts +0 -1
  463. package/dist/src/utils/browserDoesNotSupportHover.test.js +0 -24
  464. package/dist/src/utils/browserDoesNotSupportHover.ts +0 -2
  465. package/dist/src/utils/clamp.ts +0 -17
  466. package/dist/src/utils/className.ts +0 -44
  467. package/dist/src/utils/event.ts +0 -1
  468. package/dist/src/utils/flattenChildren.test.tsx +0 -58
  469. package/dist/src/utils/flattenChildren.ts +0 -27
  470. package/dist/src/utils/focus/constants.ts +0 -5
  471. package/dist/src/utils/focus/getFirstAndLastFocusable.test.ts +0 -134
  472. package/dist/src/utils/focus/getFirstAndLastFocusable.ts +0 -21
  473. package/dist/src/utils/focus/getFocusableElements.test.ts +0 -151
  474. package/dist/src/utils/focus/getFocusableElements.ts +0 -7
  475. package/dist/src/utils/index.ts +0 -5
  476. package/dist/src/utils/isInternetExplorer.ts +0 -15
  477. package/dist/src/utils/makeListenerTowerContext.ts +0 -32
  478. package/dist/src/utils/mergeRefs.ts +0 -22
  479. package/dist/src/utils/partitionMulti.ts +0 -28
  480. package/dist/src/utils/renderLink.tsx +0 -17
  481. package/dist/src/utils/type.ts +0 -113
  482. package/dist/src/utils/userHasReducedMotion.ts +0 -7
  483. package/dist/src/utils/utils.test.ts +0 -48
  484. package/jest/__mocks__/@storybook/addon-actions.js +0 -3
  485. package/jest/__mocks__/@storybook/addon-knobs.js +0 -6
  486. package/jest/__mocks__/emptyFileMockTransformer.js +0 -8
  487. package/jest/__mocks__/emptyModuleMock.js +0 -1
  488. package/jest/configure.js +0 -6
  489. package/jest/index.js +0 -36
  490. package/jest/transform.js +0 -6
  491. package/rollup.config.js +0 -98
  492. package/storybook/build +0 -4
  493. package/storybook/generate-demo-stories.js +0 -59
  494. package/storybook/main.js +0 -67
  495. package/storybook/package.json +0 -13
  496. package/storybook/preview.js +0 -11
  497. package/storybook/start +0 -4
  498. package/storybook/story-block/StoryBlock.tsx +0 -49
  499. package/storybook/story-block/decorator.jsx +0 -7
  500. package/storybook/story-block/index.scss +0 -27
  501. package/storybook/yarn.lock +0 -13192
  502. package/tsconfig.json +0 -3
@@ -1,92 +0,0 @@
1
- import React, { useEffect } from 'react';
2
- import { getFocusableElements } from '@lumx/react/utils/focus/getFocusableElements';
3
-
4
- export interface UseSlideFocusManagementProps {
5
- isSlideDisplayed?: boolean;
6
- slideRef: React.RefObject<HTMLDivElement>;
7
- }
8
-
9
- /**
10
- * Classname set on elements whose focus was blocked.
11
- * This is to easily find elements that have been tempered with,
12
- * and not elements whose focus was already initially blocked.
13
- * */
14
- const BLOCKED_FOCUS_CLASSNAME = `focus-blocked`;
15
-
16
- /**
17
- * Manage how slides must behave when visible or not.
18
- * When not visible, they should be hidden from screen readers and not focusable.
19
- */
20
- export const useSlideFocusManagement = ({ isSlideDisplayed, slideRef }: UseSlideFocusManagementProps) => {
21
- useEffect(() => {
22
- const element = slideRef?.current;
23
-
24
- if (!element) {
25
- return undefined;
26
- }
27
-
28
- /**
29
- * Display given slide to screen readers and, if focus was blocked, restore focus on elements.
30
- */
31
- const enableSlide = () => {
32
- // Hide from screen readers
33
- element.setAttribute('aria-hidden', 'false');
34
- // Find elements we have blocked focus on
35
- element.querySelectorAll(`.${BLOCKED_FOCUS_CLASSNAME}`).forEach((focusableElement) => {
36
- focusableElement.removeAttribute('tabindex');
37
- focusableElement.classList.remove(BLOCKED_FOCUS_CLASSNAME);
38
- });
39
- };
40
-
41
- /**
42
- * Hide given slide from screen readers and block focus on all focusable elements within.
43
- */
44
- const blockSlide = () => {
45
- element.setAttribute('aria-hidden', 'true');
46
- getFocusableElements(element).forEach((focusableElement) => {
47
- focusableElement.setAttribute('tabindex', '-1');
48
- focusableElement.classList.add(BLOCKED_FOCUS_CLASSNAME);
49
- });
50
- };
51
-
52
- const handleDisplay = () => {
53
- if (!element) {
54
- return;
55
- }
56
- if (isSlideDisplayed) {
57
- enableSlide();
58
- } else {
59
- blockSlide();
60
- }
61
- };
62
-
63
- // Callback function to execute when mutations are observed
64
- const callback: MutationCallback = (mutationsList) => {
65
- if (element) {
66
- for (const mutation of mutationsList) {
67
- if (mutation.type === 'childList') {
68
- handleDisplay();
69
- }
70
- }
71
- }
72
- };
73
-
74
- // Create an observer instance linked to the callback function
75
- const observer = new MutationObserver(callback);
76
-
77
- if (element) {
78
- handleDisplay();
79
-
80
- /** If slide is hidden, start observing for elements to block focus */
81
- if (!isSlideDisplayed) {
82
- observer.observe(element, { attributes: true, childList: true, subtree: true });
83
- }
84
- }
85
-
86
- return () => {
87
- if (!isSlideDisplayed) {
88
- observer.disconnect();
89
- }
90
- };
91
- }, [isSlideDisplayed, slideRef]);
92
- };
@@ -1,18 +0,0 @@
1
- import { useEffect } from 'react';
2
- import { detectHorizontalSwipe } from '@lumx/core/js/utils';
3
-
4
- const isTouchDevice = () => 'ontouchstart' in window;
5
-
6
- /**
7
- * Listen swipe to navigate left and right.
8
- */
9
- export function useSwipeNavigate(element?: HTMLElement | null, onNext?: () => void, onPrevious?: () => void): void {
10
- useEffect(() => {
11
- if (!element || !isTouchDevice()) return undefined;
12
-
13
- return detectHorizontalSwipe(element, (swipe) => {
14
- const callback = swipe === 'right' ? onPrevious : onNext;
15
- callback?.();
16
- });
17
- }, [onPrevious, onNext, element]);
18
- }
@@ -1,36 +0,0 @@
1
- import { Switch, Alignment } from '@lumx/react';
2
- import { text } from '@storybook/addon-knobs';
3
- import noop from 'lodash/noop';
4
- import React from 'react';
5
-
6
- export default { title: 'LumX components/switch/Switch' };
7
-
8
- export const NotCheckedSwitch = ({ theme }: any) => (
9
- <Switch isChecked={false} onChange={noop} theme={theme}>
10
- {text('text', 'The switch')}
11
- </Switch>
12
- );
13
-
14
- export const CheckedSwitch = ({ theme }: any) => (
15
- <Switch isChecked onChange={noop} theme={theme}>
16
- {text('text', 'The switch')}
17
- </Switch>
18
- );
19
-
20
- export const DisabledCheckedSwitch = ({ theme }: any) => (
21
- <Switch isChecked isDisabled onChange={noop} theme={theme}>
22
- {text('text', 'The switch')}
23
- </Switch>
24
- );
25
-
26
- export const DisabledSwitch = ({ theme }: any) => (
27
- <Switch isDisabled onChange={noop} theme={theme}>
28
- {text('text', 'The switch')}
29
- </Switch>
30
- );
31
-
32
- export const RightPositionSwitch = ({ theme }: any) => (
33
- <Switch position={Alignment.right} onChange={noop} theme={theme}>
34
- {text('text', 'The switch')}
35
- </Switch>
36
- );
@@ -1,189 +0,0 @@
1
- import React, { ReactElement } from 'react';
2
-
3
- import { mount, shallow } from 'enzyme';
4
- import 'jest-enzyme';
5
- import { build, oneOf } from 'test-data-bot';
6
-
7
- import without from 'lodash/without';
8
-
9
- import { Wrapper, commonTestsSuite } from '@lumx/react/testing/utils';
10
- import { getBasicClass } from '@lumx/react/utils/className';
11
-
12
- import { Theme, Alignment } from '@lumx/react';
13
- import { Switch, SwitchProps } from './Switch';
14
-
15
- const DEFAULT_PROPS = Switch.defaultProps as any;
16
- const CLASSNAME = Switch.className as string;
17
-
18
- type SetupProps = Partial<SwitchProps>;
19
-
20
- /**
21
- * Mounts the component and returns common DOM elements / data needed in multiple tests further down.
22
- */
23
- const setup = ({ ...propsOverride }: SetupProps = {}, shallowRendering = true) => {
24
- const props: SwitchProps = {
25
- ...propsOverride,
26
- };
27
-
28
- const renderer: (el: ReactElement) => Wrapper = shallowRendering ? shallow : mount;
29
-
30
- const wrapper: Wrapper = renderer(<Switch {...props} />);
31
-
32
- return {
33
- root: wrapper.find('div').first(),
34
-
35
- input: wrapper.find('input'),
36
- inputWrapper: wrapper.find(`.${CLASSNAME}__input-wrapper`),
37
-
38
- content: wrapper.find(`.${CLASSNAME}__content`),
39
- helper: wrapper.find(`.${CLASSNAME}__helper`),
40
- label: wrapper.find(`.${CLASSNAME}__label`),
41
-
42
- props,
43
- wrapper,
44
- };
45
- };
46
-
47
- jest.mock('uid', () => ({ uid: () => 'uid' }));
48
-
49
- describe(`<${Switch.displayName}>`, () => {
50
- // 1. Test render via snapshot (default states of component).
51
- describe('Snapshots and structure', () => {
52
- it('should render correctly without any label', () => {
53
- const { root, inputWrapper, input, content, wrapper } = setup();
54
- expect(wrapper).toMatchSnapshot();
55
-
56
- expect(root).toExist();
57
- expect(root).toHaveClassName(CLASSNAME);
58
-
59
- expect(inputWrapper).toExist();
60
- expect(input).toExist();
61
-
62
- expect(content).not.toExist();
63
- });
64
-
65
- it('should render correctly with only a `label`', () => {
66
- const props: SetupProps = { children: 'Label' };
67
- const { root, inputWrapper, input, content, helper, label, wrapper } = setup(props);
68
- expect(wrapper).toMatchSnapshot();
69
-
70
- expect(root).toExist();
71
- expect(root).toHaveClassName(CLASSNAME);
72
-
73
- expect(inputWrapper).toExist();
74
- expect(input).toExist();
75
-
76
- expect(content).toExist();
77
- expect(label).toExist();
78
- expect(helper).not.toExist();
79
- });
80
-
81
- it('should render correctly with a `label` and a `helper`', () => {
82
- const props: SetupProps = { children: 'Label', helper: 'Helper' };
83
- const { root, inputWrapper, input, content, helper, label, wrapper } = setup(props);
84
- expect(wrapper).toMatchSnapshot();
85
-
86
- expect(root).toExist();
87
- expect(root).toHaveClassName(CLASSNAME);
88
-
89
- expect(inputWrapper).toExist();
90
- expect(input).toExist();
91
-
92
- expect(content).toExist();
93
- expect(label).toExist();
94
- expect(helper).toExist();
95
- });
96
- });
97
-
98
- // 2. Test defaultProps value and important props custom values.
99
- describe('Props', () => {
100
- it('should use default props', () => {
101
- const { root } = setup();
102
-
103
- Object.keys(DEFAULT_PROPS).forEach((prop: string) => {
104
- let defaultProp: any = DEFAULT_PROPS[prop];
105
-
106
- if (prop === 'checked') {
107
- // eslint-disable-next-line no-param-reassign
108
- prop = 'unchecked';
109
- defaultProp = true;
110
- }
111
-
112
- expect(root).toHaveClassName(getBasicClass({ prefix: CLASSNAME, type: prop, value: defaultProp }));
113
- });
114
- });
115
-
116
- it('should use the given props', () => {
117
- const modifiedPropsBuilder: () => SetupProps = build('props').fields({
118
- isChecked: true,
119
- position: oneOf(...without(Object.values(Alignment), DEFAULT_PROPS.position)),
120
- theme: oneOf(...without(Object.values(Theme), DEFAULT_PROPS.theme)),
121
- });
122
-
123
- const modifiedProps: SetupProps = modifiedPropsBuilder();
124
-
125
- const { root } = setup({ ...modifiedProps });
126
-
127
- Object.keys(modifiedProps).forEach((prop: string) => {
128
- if (prop === 'checked') {
129
- if (modifiedProps[prop]) {
130
- expect(root).toHaveClassName(
131
- getBasicClass({ prefix: CLASSNAME, type: prop, value: modifiedProps[prop] }),
132
- );
133
- } else {
134
- expect(root).toHaveClassName(
135
- getBasicClass({ prefix: CLASSNAME, type: 'unchecked', value: true }),
136
- );
137
- }
138
- } else {
139
- expect(root).toHaveClassName(
140
- getBasicClass({ prefix: CLASSNAME, type: prop, value: modifiedProps[prop] }),
141
- );
142
- }
143
- });
144
- });
145
-
146
- it('should use the given props while passing custom props to input', () => {
147
- const { wrapper } = setup({
148
- inputProps: {
149
- 'aria-labelledby': 'labelledby-id',
150
- },
151
- });
152
-
153
- expect(wrapper).toMatchSnapshot();
154
- });
155
- });
156
-
157
- // 3. Test events.
158
- describe('Events', () => {
159
- const onChange: jest.Mock = jest.fn();
160
-
161
- beforeEach(() => {
162
- onChange.mockClear();
163
- });
164
-
165
- it('should trigger `onChange` when toggled', () => {
166
- const { input } = setup({ onChange }, false);
167
-
168
- input.simulate('change');
169
- expect(onChange).toHaveBeenCalled();
170
- });
171
- });
172
-
173
- // 4. Test conditions (i.e. things that display or not in the UI based on props).
174
- describe('Conditions', () => {
175
- it('should not display the `helper` if no `label` is given', () => {
176
- const props: SetupProps = { helper: 'Helper' };
177
- const { content, wrapper } = setup(props);
178
- expect(wrapper).toMatchSnapshot();
179
-
180
- expect(content).not.toExist();
181
- });
182
- });
183
-
184
- // 5. Test state.
185
- // N/A
186
-
187
- // Common tests suite.
188
- commonTestsSuite(setup, { className: 'root', prop: 'root' }, { className: CLASSNAME });
189
- });
@@ -1,141 +0,0 @@
1
- import React, { Children, forwardRef, InputHTMLAttributes, SyntheticEvent, useMemo } from 'react';
2
-
3
- import classNames from 'classnames';
4
- import { uid } from 'uid';
5
-
6
- import isEmpty from 'lodash/isEmpty';
7
-
8
- import { Alignment, InputHelper, InputLabel, Theme } from '@lumx/react';
9
-
10
- import { Comp, GenericProps, HasTheme } from '@lumx/react/utils/type';
11
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
12
-
13
- /**
14
- * Defines the props of the component.
15
- */
16
- export interface SwitchProps extends GenericProps, HasTheme {
17
- /** Helper text. */
18
- helper?: string;
19
- /** Whether it is checked or not. */
20
- isChecked?: boolean;
21
- /** Whether the component is disabled or not. */
22
- isDisabled?: boolean;
23
- /** Native input name property. */
24
- name?: string;
25
- /** Position of the switch relative to the label. */
26
- position?: Extract<Alignment, 'right' | 'left'>;
27
- /** Native input value property. */
28
- value?: string;
29
- /** On change callback. */
30
- onChange?(isChecked: boolean, value?: string, name?: string, event?: SyntheticEvent): void;
31
- /** optional props for input */
32
- inputProps?: InputHTMLAttributes<HTMLInputElement>;
33
- }
34
-
35
- /**
36
- * Component display name.
37
- */
38
- const COMPONENT_NAME = 'Switch';
39
-
40
- /**
41
- * Component default class name and class prefix.
42
- */
43
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
44
-
45
- /**
46
- * Component default props.
47
- */
48
- const DEFAULT_PROPS: Partial<SwitchProps> = {
49
- position: Alignment.left,
50
- theme: Theme.light,
51
- };
52
-
53
- /**
54
- * Switch component.
55
- *
56
- * @param props Component props.
57
- * @param ref Component ref.
58
- * @return React element.
59
- */
60
- export const Switch: Comp<SwitchProps, HTMLDivElement> = forwardRef((props, ref) => {
61
- const {
62
- checked,
63
- children,
64
- className,
65
- disabled,
66
- helper,
67
- id,
68
- isChecked = checked,
69
- isDisabled = disabled,
70
- name,
71
- onChange,
72
- position,
73
- theme,
74
- value,
75
- inputProps = {},
76
- ...forwardedProps
77
- } = props;
78
- const inputId = useMemo(() => id || `switch-${uid()}`, [id]);
79
- const handleChange = (event: React.ChangeEvent<HTMLInputElement>) => {
80
- if (onChange) {
81
- onChange(!isChecked, value, name, event);
82
- }
83
- };
84
-
85
- return (
86
- <div
87
- ref={ref}
88
- {...forwardedProps}
89
- className={classNames(
90
- className,
91
- handleBasicClasses({
92
- prefix: CLASSNAME,
93
- isChecked,
94
- isDisabled,
95
- position,
96
- theme,
97
- isUnchecked: !isChecked,
98
- }),
99
- )}
100
- aria-disabled={isDisabled}
101
- >
102
- <div className={`${CLASSNAME}__input-wrapper`}>
103
- <input
104
- type="checkbox"
105
- role="switch"
106
- id={inputId}
107
- className={`${CLASSNAME}__input-native`}
108
- name={name}
109
- value={value}
110
- disabled={isDisabled}
111
- checked={isChecked}
112
- aria-checked={Boolean(isChecked)}
113
- onChange={handleChange}
114
- aria-describedby={helper ? `${inputId}-helper` : undefined}
115
- {...inputProps}
116
- />
117
-
118
- <div className={`${CLASSNAME}__input-placeholder`}>
119
- <div className={`${CLASSNAME}__input-background`} />
120
- <div className={`${CLASSNAME}__input-indicator`} />
121
- </div>
122
- </div>
123
-
124
- {Children.count(children) > 0 && (
125
- <div className={`${CLASSNAME}__content`}>
126
- <InputLabel htmlFor={inputId} theme={theme} className={`${CLASSNAME}__label`}>
127
- {children}
128
- </InputLabel>
129
- {!isEmpty(helper) && (
130
- <InputHelper id={`${inputId}-helper`} theme={theme} className={`${CLASSNAME}__helper`}>
131
- {helper}
132
- </InputHelper>
133
- )}
134
- </div>
135
- )}
136
- </div>
137
- );
138
- });
139
- Switch.displayName = COMPONENT_NAME;
140
- Switch.className = CLASSNAME;
141
- Switch.defaultProps = DEFAULT_PROPS;
@@ -1,179 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`<Switch> Conditions should not display the \`helper\` if no \`label\` is given 1`] = `
4
- <div
5
- className="lumx-switch lumx-switch--position-left lumx-switch--theme-light lumx-switch--is-unchecked"
6
- >
7
- <div
8
- className="lumx-switch__input-wrapper"
9
- >
10
- <input
11
- aria-checked={false}
12
- aria-describedby="switch-uid-helper"
13
- className="lumx-switch__input-native"
14
- id="switch-uid"
15
- onChange={[Function]}
16
- role="switch"
17
- type="checkbox"
18
- />
19
- <div
20
- className="lumx-switch__input-placeholder"
21
- >
22
- <div
23
- className="lumx-switch__input-background"
24
- />
25
- <div
26
- className="lumx-switch__input-indicator"
27
- />
28
- </div>
29
- </div>
30
- </div>
31
- `;
32
-
33
- exports[`<Switch> Props should use the given props while passing custom props to input 1`] = `
34
- <div
35
- className="lumx-switch lumx-switch--position-left lumx-switch--theme-light lumx-switch--is-unchecked"
36
- >
37
- <div
38
- className="lumx-switch__input-wrapper"
39
- >
40
- <input
41
- aria-checked={false}
42
- aria-labelledby="labelledby-id"
43
- className="lumx-switch__input-native"
44
- id="switch-uid"
45
- onChange={[Function]}
46
- role="switch"
47
- type="checkbox"
48
- />
49
- <div
50
- className="lumx-switch__input-placeholder"
51
- >
52
- <div
53
- className="lumx-switch__input-background"
54
- />
55
- <div
56
- className="lumx-switch__input-indicator"
57
- />
58
- </div>
59
- </div>
60
- </div>
61
- `;
62
-
63
- exports[`<Switch> Snapshots and structure should render correctly with a \`label\` and a \`helper\` 1`] = `
64
- <div
65
- className="lumx-switch lumx-switch--position-left lumx-switch--theme-light lumx-switch--is-unchecked"
66
- >
67
- <div
68
- className="lumx-switch__input-wrapper"
69
- >
70
- <input
71
- aria-checked={false}
72
- aria-describedby="switch-uid-helper"
73
- className="lumx-switch__input-native"
74
- id="switch-uid"
75
- onChange={[Function]}
76
- role="switch"
77
- type="checkbox"
78
- />
79
- <div
80
- className="lumx-switch__input-placeholder"
81
- >
82
- <div
83
- className="lumx-switch__input-background"
84
- />
85
- <div
86
- className="lumx-switch__input-indicator"
87
- />
88
- </div>
89
- </div>
90
- <div
91
- className="lumx-switch__content"
92
- >
93
- <InputLabel
94
- className="lumx-switch__label"
95
- htmlFor="switch-uid"
96
- theme="light"
97
- >
98
- Label
99
- </InputLabel>
100
- <InputHelper
101
- className="lumx-switch__helper"
102
- id="switch-uid-helper"
103
- kind="info"
104
- theme="light"
105
- >
106
- Helper
107
- </InputHelper>
108
- </div>
109
- </div>
110
- `;
111
-
112
- exports[`<Switch> Snapshots and structure should render correctly with only a \`label\` 1`] = `
113
- <div
114
- className="lumx-switch lumx-switch--position-left lumx-switch--theme-light lumx-switch--is-unchecked"
115
- >
116
- <div
117
- className="lumx-switch__input-wrapper"
118
- >
119
- <input
120
- aria-checked={false}
121
- className="lumx-switch__input-native"
122
- id="switch-uid"
123
- onChange={[Function]}
124
- role="switch"
125
- type="checkbox"
126
- />
127
- <div
128
- className="lumx-switch__input-placeholder"
129
- >
130
- <div
131
- className="lumx-switch__input-background"
132
- />
133
- <div
134
- className="lumx-switch__input-indicator"
135
- />
136
- </div>
137
- </div>
138
- <div
139
- className="lumx-switch__content"
140
- >
141
- <InputLabel
142
- className="lumx-switch__label"
143
- htmlFor="switch-uid"
144
- theme="light"
145
- >
146
- Label
147
- </InputLabel>
148
- </div>
149
- </div>
150
- `;
151
-
152
- exports[`<Switch> Snapshots and structure should render correctly without any label 1`] = `
153
- <div
154
- className="lumx-switch lumx-switch--position-left lumx-switch--theme-light lumx-switch--is-unchecked"
155
- >
156
- <div
157
- className="lumx-switch__input-wrapper"
158
- >
159
- <input
160
- aria-checked={false}
161
- className="lumx-switch__input-native"
162
- id="switch-uid"
163
- onChange={[Function]}
164
- role="switch"
165
- type="checkbox"
166
- />
167
- <div
168
- className="lumx-switch__input-placeholder"
169
- >
170
- <div
171
- className="lumx-switch__input-background"
172
- />
173
- <div
174
- className="lumx-switch__input-indicator"
175
- />
176
- </div>
177
- </div>
178
- </div>
179
- `;
@@ -1 +0,0 @@
1
- export * from './Switch';
@@ -1,28 +0,0 @@
1
- import React from 'react';
2
- import { mount, shallow } from 'enzyme';
3
- import 'jest-enzyme';
4
- import { commonTestsSuite, itShouldRenderStories } from '@lumx/react/testing/utils';
5
-
6
- import { Table, TableProps } from './Table';
7
- import * as stories from '../../stories/generated/Table/Demos.stories';
8
-
9
- const CLASSNAME = Table.className as string;
10
-
11
- /**
12
- * Mounts the component and returns common DOM elements / data needed in multiple tests further down.
13
- */
14
- const setup = (props: Partial<TableProps> = {}, shallowRendering = true) => {
15
- const renderer: any = shallowRendering ? shallow : mount;
16
- const wrapper: any = renderer(<Table {...(props as any)} />);
17
- return { props, wrapper };
18
- };
19
-
20
- describe(`<${Table.displayName}>`, () => {
21
- // 1. Test render via snapshot.
22
- describe('Snapshots and structure', () => {
23
- itShouldRenderStories(stories, Table);
24
- });
25
-
26
- // Common tests suite.
27
- commonTestsSuite(setup, { className: 'wrapper', prop: 'wrapper' }, { className: CLASSNAME });
28
- });