@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,174 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`<SkeletonTypography> Snapshots and structure should render story 'TextTypography' 1`] = `
4
- [
5
- <div
6
- className="lumx-spacing-margin-bottom lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-title"
7
- style={
8
- {
9
- "width": "30%",
10
- }
11
- }
12
- >
13
- <div
14
- className="lumx-skeleton-typography__inner"
15
- />
16
- </div>,
17
- <div
18
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1"
19
- style={
20
- {
21
- "width": undefined,
22
- }
23
- }
24
- >
25
- <div
26
- className="lumx-skeleton-typography__inner"
27
- />
28
- </div>,
29
- <div
30
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1"
31
- style={
32
- {
33
- "width": undefined,
34
- }
35
- }
36
- >
37
- <div
38
- className="lumx-skeleton-typography__inner"
39
- />
40
- </div>,
41
- <div
42
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1"
43
- style={
44
- {
45
- "width": undefined,
46
- }
47
- }
48
- >
49
- <div
50
- className="lumx-skeleton-typography__inner"
51
- />
52
- </div>,
53
- <div
54
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1"
55
- style={
56
- {
57
- "width": "70%",
58
- }
59
- }
60
- >
61
- <div
62
- className="lumx-skeleton-typography__inner"
63
- />
64
- </div>,
65
- <div
66
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1 lumx-skeleton-typography--color-primary"
67
- style={
68
- {
69
- "width": undefined,
70
- }
71
- }
72
- >
73
- <div
74
- className="lumx-skeleton-typography__inner"
75
- />
76
- </div>,
77
- <div
78
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1 lumx-skeleton-typography--color-secondary"
79
- style={
80
- {
81
- "width": undefined,
82
- }
83
- }
84
- >
85
- <div
86
- className="lumx-skeleton-typography__inner"
87
- />
88
- </div>,
89
- <div
90
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1 lumx-skeleton-typography--color-blue"
91
- style={
92
- {
93
- "width": undefined,
94
- }
95
- }
96
- >
97
- <div
98
- className="lumx-skeleton-typography__inner"
99
- />
100
- </div>,
101
- <div
102
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1 lumx-skeleton-typography--color-dark"
103
- style={
104
- {
105
- "width": undefined,
106
- }
107
- }
108
- >
109
- <div
110
- className="lumx-skeleton-typography__inner"
111
- />
112
- </div>,
113
- <div
114
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1 lumx-skeleton-typography--color-green"
115
- style={
116
- {
117
- "width": undefined,
118
- }
119
- }
120
- >
121
- <div
122
- className="lumx-skeleton-typography__inner"
123
- />
124
- </div>,
125
- <div
126
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1 lumx-skeleton-typography--color-yellow"
127
- style={
128
- {
129
- "width": undefined,
130
- }
131
- }
132
- >
133
- <div
134
- className="lumx-skeleton-typography__inner"
135
- />
136
- </div>,
137
- <div
138
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1 lumx-skeleton-typography--color-red"
139
- style={
140
- {
141
- "width": undefined,
142
- }
143
- }
144
- >
145
- <div
146
- className="lumx-skeleton-typography__inner"
147
- />
148
- </div>,
149
- <div
150
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1 lumx-skeleton-typography--color-light"
151
- style={
152
- {
153
- "width": undefined,
154
- }
155
- }
156
- >
157
- <div
158
- className="lumx-skeleton-typography__inner"
159
- />
160
- </div>,
161
- <div
162
- className="lumx-skeleton-typography lumx-skeleton-typography--theme-light lumx-skeleton-typography--typography-body1 lumx-skeleton-typography--color-grey"
163
- style={
164
- {
165
- "width": undefined,
166
- }
167
- }
168
- >
169
- <div
170
- className="lumx-skeleton-typography__inner"
171
- />
172
- </div>,
173
- ]
174
- `;
@@ -1,3 +0,0 @@
1
- export * from './SkeletonCircle';
2
- export * from './SkeletonRectangle';
3
- export * from './SkeletonTypography';
@@ -1,29 +0,0 @@
1
- import { Slider } from '@lumx/react';
2
- import { number, text } from '@storybook/addon-knobs';
3
- import noop from 'lodash/noop';
4
- import React from 'react';
5
-
6
- export default { title: 'LumX components/slider/Slider' };
7
-
8
- export const DefaultSlider = ({ theme }: any) => (
9
- <Slider
10
- label={text('label', 'Default')}
11
- max={number('max', 10)}
12
- min={number('min', 0)}
13
- theme={theme}
14
- value={5}
15
- onChange={noop}
16
- />
17
- );
18
-
19
- export const WithHelperSlider = ({ theme }: any) => (
20
- <Slider
21
- label={text('label', 'Default')}
22
- helper={text('helper', 'This is an helper text')}
23
- max={number('max', 10)}
24
- min={number('min', 0)}
25
- theme={theme}
26
- value={5}
27
- onChange={noop}
28
- />
29
- );
@@ -1,31 +0,0 @@
1
- import React from 'react';
2
-
3
- import { mount, shallow } from 'enzyme';
4
- import 'jest-enzyme';
5
- import { commonTestsSuite, itShouldRenderStories } from '@lumx/react/testing/utils';
6
-
7
- import { Slider, SliderProps } from './Slider';
8
- import * as stories from './Slider.stories';
9
-
10
- const CLASSNAME = Slider.className as string;
11
-
12
- jest.mock('uid', () => ({ uid: () => 'uid' }));
13
-
14
- /**
15
- * Mounts the component and returns common DOM elements / data needed in multiple tests further down.
16
- */
17
- const setup = (props: Partial<SliderProps> = {}, shallowRendering = true) => {
18
- const renderer: any = shallowRendering ? shallow : mount;
19
- const wrapper: any = renderer(<Slider {...(props as any)} />);
20
- return { props, wrapper };
21
- };
22
-
23
- describe(`<${Slider.displayName}>`, () => {
24
- // 1. Test render via snapshot.
25
- describe('Snapshots and structure', () => {
26
- itShouldRenderStories(stories, Slider);
27
- });
28
-
29
- // Common tests suite.
30
- commonTestsSuite(setup, { className: 'wrapper', prop: 'wrapper' }, { className: CLASSNAME });
31
- });
@@ -1,299 +0,0 @@
1
- /* eslint-disable jsx-a11y/no-static-element-interactions */
2
- import React, { forwardRef, SyntheticEvent, useMemo, useRef } from 'react';
3
-
4
- import classNames from 'classnames';
5
-
6
- import { InputHelper, InputLabel, Theme } from '@lumx/react';
7
-
8
- import useEventCallback from '@lumx/react/hooks/useEventCallback';
9
- import { Comp, GenericProps, HasTheme } from '@lumx/react/utils/type';
10
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
11
-
12
- import { uid } from 'uid';
13
- import { clamp } from '@lumx/react/utils/clamp';
14
-
15
- /**
16
- * Defines the props of the component.
17
- */
18
- export interface SliderProps extends GenericProps, HasTheme {
19
- /** Helper text. */
20
- helper?: string;
21
- /** Whether the min and max labels should be hidden or not. */
22
- hideMinMaxLabel?: boolean;
23
- /** Whether the component is disabled or not. */
24
- isDisabled?: boolean;
25
- /** Label text. */
26
- label?: string;
27
- /** Maximum value on the range. */
28
- max: number;
29
- /** Minimum value of the range. */
30
- min: number;
31
- /** Native input name property. */
32
- name?: string;
33
- /** Number of digits in the fractional part of the selected value. */
34
- precision?: number;
35
- /** Range step value. */
36
- steps?: number;
37
- /** Selected ranged value. */
38
- value: number;
39
- /** On change callback. */
40
- onChange(value: number, name?: string, event?: SyntheticEvent): void;
41
- /** On click callback. */
42
- onMouseDown?(event: React.SyntheticEvent): void;
43
- }
44
-
45
- /**
46
- * Component display name.
47
- */
48
- const COMPONENT_NAME = 'Slider';
49
-
50
- /**
51
- * Component default class name and class prefix.
52
- */
53
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
54
-
55
- /**
56
- * Component default props.
57
- */
58
- const DEFAULT_PROPS: Partial<SliderProps> = {
59
- precision: 0,
60
- steps: 0,
61
- theme: Theme.light,
62
- };
63
-
64
- /**
65
- * Convert a percent value to a value in range min - max.
66
- *
67
- * @param percent Value to convert.
68
- * @param min Minimum value.
69
- * @param max Maximum value.
70
- * @param precision Precision.
71
- * @return Value in range min - max
72
- */
73
- const computeValueFromPercent = (percent: number, min: number, max: number, precision = 0): number =>
74
- Number((min + percent * (max - min)).toFixed(precision));
75
-
76
- /**
77
- * Convert a value in range min - max to a percent value.
78
- *
79
- * @param value Value to convert.
80
- * @param min Minimum value.
81
- * @param max Maximum value.
82
- * @return Value in percent
83
- */
84
- const computePercentFromValue = (value: number, min: number, max: number): number =>
85
- Number((value - min) / (max - min));
86
-
87
- /**
88
- * Slider component.
89
- *
90
- * @param props Component props.
91
- * @param ref Component ref.
92
- * @return React element.
93
- */
94
- export const Slider: Comp<SliderProps, HTMLDivElement> = forwardRef((props, ref) => {
95
- const {
96
- className,
97
- disabled,
98
- helper,
99
- hideMinMaxLabel,
100
- id,
101
- isDisabled = disabled,
102
- label,
103
- max,
104
- min,
105
- name,
106
- onChange,
107
- onMouseDown,
108
- precision,
109
- steps,
110
- theme,
111
- value,
112
- ...forwardedProps
113
- } = props;
114
- const sliderId = useMemo(() => id || `slider-${uid()}`, [id]);
115
- const sliderLabelId = useMemo(() => `label-${sliderId}`, [sliderId]);
116
- const sliderRef = useRef<HTMLDivElement>(null);
117
-
118
- // build a lookup array for the steps.
119
- const availableSteps = useMemo((): number[] => {
120
- if (!steps) return [];
121
-
122
- const available = [0];
123
- const percentStep = 1 / ((max - min) / steps);
124
- let ptr = 0;
125
- while (ptr + percentStep < 1) {
126
- ptr += percentStep;
127
- available.push(ptr);
128
- }
129
- return available;
130
- }, [steps, min, max]);
131
-
132
- /**
133
- * Try to find the closest step to the current slider position.
134
- *
135
- * @param percentValue Reference value
136
- * @return The closest step value
137
- */
138
- const findClosestStep = (percentValue: number): number => {
139
- const closest = availableSteps.reduce(
140
- (acc, step) => {
141
- const aDst = Math.abs(percentValue - step);
142
- if (aDst < acc.dst) {
143
- return { dst: aDst, val: step };
144
- }
145
- return acc;
146
- },
147
- { dst: Infinity, val: -1 },
148
- );
149
- return closest.val;
150
- };
151
-
152
- /**
153
- * Convert slider's handle position to percent.
154
- *
155
- * @param event The interaction event
156
- * @param slider the slider element
157
- * @return The computed percent value
158
- */
159
- const getPercentValue = (event: React.MouseEvent, slider: HTMLDivElement): number => {
160
- const { width, left } = slider.getBoundingClientRect();
161
- let percent = (event.pageX - left - window.pageXOffset) / width;
162
- percent = clamp(percent, 0, 1);
163
- if (steps) {
164
- percent = findClosestStep(percent);
165
- }
166
- return percent;
167
- };
168
-
169
- /**
170
- * Register a handler for the mouse move event.
171
- */
172
- const handleMove = useEventCallback((event: React.MouseEvent) => {
173
- const { current: slider } = sliderRef;
174
- if (!slider || !onChange) return;
175
- const newValue = getPercentValue(event, slider);
176
- onChange(computeValueFromPercent(newValue, min, max, precision), name, event);
177
- });
178
-
179
- /**
180
- * Register a handler for the mouse up event.
181
- * Clean a all listeners.
182
- */
183
- const handleEnd = useEventCallback(() => {
184
- document.body.removeEventListener('mousemove', handleMove);
185
- document.body.removeEventListener('mouseup', handleEnd);
186
- document.body.removeEventListener('touchmove', handleMove);
187
- document.body.removeEventListener('touchend', handleEnd);
188
- });
189
-
190
- /**
191
- * Move to the next or previous value (i.e. + or - 10%) or next step
192
- * @param previous Should seek the previous value.
193
- */
194
- const hopToValue = (previous = false) => {
195
- const oldPercent = computePercentFromValue(value, min, max);
196
- let percent = clamp(oldPercent + (previous ? -0.1 : 0.1), 0, 1);
197
- if (steps) {
198
- percent = oldPercent + availableSteps[1] * (previous ? -1 : 1);
199
- percent = findClosestStep(percent);
200
- }
201
- if (onChange) {
202
- onChange(computeValueFromPercent(percent, min, max, precision), name);
203
- }
204
- };
205
-
206
- /**
207
- * Register a handler for keyboard interactions
208
- */
209
- const handleKeyDown = useEventCallback((event: React.KeyboardEvent) => {
210
- if (event.key === 'ArrowRight') {
211
- hopToValue();
212
- } else if (event.key === 'ArrowLeft') {
213
- hopToValue(true);
214
- }
215
- });
216
-
217
- /**
218
- * Register a handler for the mouseDown event.
219
- */
220
- const handleMouseDown = useEventCallback((event: React.MouseEvent) => {
221
- onMouseDown?.(event);
222
-
223
- const { current: slider } = sliderRef;
224
- if (isDisabled || !slider) return;
225
- const newValue = getPercentValue(event, slider);
226
- if (onChange) {
227
- onChange(computeValueFromPercent(newValue, min, max, precision), name, event);
228
- }
229
-
230
- document.body.addEventListener('mousemove', handleMove);
231
- document.body.addEventListener('mouseup', handleEnd);
232
- });
233
-
234
- const percentString = `${computePercentFromValue(value, min, max) * 100}%`;
235
- return (
236
- <div
237
- ref={ref}
238
- {...forwardedProps}
239
- className={classNames(
240
- className,
241
- handleBasicClasses({ prefix: CLASSNAME, theme, hasLabel: Boolean(label) }),
242
- )}
243
- onMouseDown={handleMouseDown}
244
- aria-disabled={isDisabled}
245
- >
246
- {label && (
247
- <InputLabel id={sliderLabelId} htmlFor={sliderId} className={`${CLASSNAME}__label`} theme={theme}>
248
- {label}
249
- </InputLabel>
250
- )}
251
-
252
- {helper && (
253
- <InputHelper className={`${CLASSNAME}__helper`} theme={theme}>
254
- {helper}
255
- </InputHelper>
256
- )}
257
-
258
- <div className={`${CLASSNAME}__ui-wrapper`}>
259
- {!hideMinMaxLabel && (
260
- <span className={`${CLASSNAME}__value-label ${CLASSNAME}__value-label--min`}>{min}</span>
261
- )}
262
- <div className={`${CLASSNAME}__wrapper`} ref={sliderRef}>
263
- <div className={`${CLASSNAME}__track ${CLASSNAME}__track--background`} />
264
- <div
265
- className={`${CLASSNAME}__track ${CLASSNAME}__track--active`}
266
- style={{ width: percentString }}
267
- />
268
- {steps ? (
269
- <div className={`${CLASSNAME}__ticks`}>
270
- {availableSteps.map((step, idx) => (
271
- <div
272
- key={`tick_${idx}`}
273
- className={`${CLASSNAME}__tick`}
274
- style={{ left: `${step * 100}%` }}
275
- />
276
- ))}
277
- </div>
278
- ) : null}
279
- <button
280
- type="button"
281
- aria-labelledby={sliderLabelId}
282
- name={name}
283
- id={sliderId}
284
- className={`${CLASSNAME}__handle`}
285
- style={{ left: percentString }}
286
- onKeyDown={handleKeyDown}
287
- disabled={isDisabled}
288
- />
289
- </div>
290
- {!hideMinMaxLabel && (
291
- <span className={`${CLASSNAME}__value-label ${CLASSNAME}__value-label--max`}>{max}</span>
292
- )}
293
- </div>
294
- </div>
295
- );
296
- });
297
- Slider.displayName = COMPONENT_NAME;
298
- Slider.className = CLASSNAME;
299
- Slider.defaultProps = DEFAULT_PROPS;
@@ -1,122 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`<Slider> Snapshots and structure should render story 'DefaultSlider' 1`] = `
4
- <div
5
- className="lumx-slider lumx-slider--theme-light lumx-slider--has-label"
6
- onMouseDown={[Function]}
7
- >
8
- <InputLabel
9
- className="lumx-slider__label"
10
- htmlFor="slider-uid"
11
- id="label-slider-uid"
12
- theme="light"
13
- >
14
- Default
15
- </InputLabel>
16
- <div
17
- className="lumx-slider__ui-wrapper"
18
- >
19
- <span
20
- className="lumx-slider__value-label lumx-slider__value-label--min"
21
- >
22
- 0
23
- </span>
24
- <div
25
- className="lumx-slider__wrapper"
26
- >
27
- <div
28
- className="lumx-slider__track lumx-slider__track--background"
29
- />
30
- <div
31
- className="lumx-slider__track lumx-slider__track--active"
32
- style={
33
- {
34
- "width": "50%",
35
- }
36
- }
37
- />
38
- <button
39
- aria-labelledby="label-slider-uid"
40
- className="lumx-slider__handle"
41
- id="slider-uid"
42
- onKeyDown={[Function]}
43
- style={
44
- {
45
- "left": "50%",
46
- }
47
- }
48
- type="button"
49
- />
50
- </div>
51
- <span
52
- className="lumx-slider__value-label lumx-slider__value-label--max"
53
- >
54
- 10
55
- </span>
56
- </div>
57
- </div>
58
- `;
59
-
60
- exports[`<Slider> Snapshots and structure should render story 'WithHelperSlider' 1`] = `
61
- <div
62
- className="lumx-slider lumx-slider--theme-light lumx-slider--has-label"
63
- onMouseDown={[Function]}
64
- >
65
- <InputLabel
66
- className="lumx-slider__label"
67
- htmlFor="slider-uid"
68
- id="label-slider-uid"
69
- theme="light"
70
- >
71
- Default
72
- </InputLabel>
73
- <InputHelper
74
- className="lumx-slider__helper"
75
- kind="info"
76
- theme="light"
77
- >
78
- This is an helper text
79
- </InputHelper>
80
- <div
81
- className="lumx-slider__ui-wrapper"
82
- >
83
- <span
84
- className="lumx-slider__value-label lumx-slider__value-label--min"
85
- >
86
- 0
87
- </span>
88
- <div
89
- className="lumx-slider__wrapper"
90
- >
91
- <div
92
- className="lumx-slider__track lumx-slider__track--background"
93
- />
94
- <div
95
- className="lumx-slider__track lumx-slider__track--active"
96
- style={
97
- {
98
- "width": "50%",
99
- }
100
- }
101
- />
102
- <button
103
- aria-labelledby="label-slider-uid"
104
- className="lumx-slider__handle"
105
- id="slider-uid"
106
- onKeyDown={[Function]}
107
- style={
108
- {
109
- "left": "50%",
110
- }
111
- }
112
- type="button"
113
- />
114
- </div>
115
- <span
116
- className="lumx-slider__value-label lumx-slider__value-label--max"
117
- >
118
- 10
119
- </span>
120
- </div>
121
- </div>
122
- `;
@@ -1,2 +0,0 @@
1
- export * from './Slider';
2
- export { clamp } from '@lumx/react/utils/clamp';