@lumx/react 3.1.0 → 3.1.2

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