@lumx/react 3.1.1 → 3.1.3-alpha.0

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