@lumx/react 3.0.7 → 3.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (517) hide show
  1. package/{CONTRIBUTING.md → dist/CONTRIBUTING.md} +0 -0
  2. package/{LICENSE.md → dist/LICENSE.md} +0 -0
  3. package/dist/README.md +38 -0
  4. package/{_internal → dist/_internal}/ClickAwayProvider.js +0 -0
  5. package/{_internal → dist/_internal}/ClickAwayProvider.js.map +0 -0
  6. package/{_internal → dist/_internal}/types.d.ts +1 -1
  7. package/{index.d.ts → dist/index.d.ts} +67 -8
  8. package/{index.js → dist/index.js} +766 -613
  9. package/dist/index.js.map +1 -0
  10. package/dist/package.json +117 -0
  11. package/dist/src/components/alert-dialog/AlertDialog.stories.tsx +196 -0
  12. package/dist/src/components/alert-dialog/AlertDialog.test.tsx +43 -0
  13. package/dist/src/components/alert-dialog/AlertDialog.tsx +185 -0
  14. package/dist/src/components/alert-dialog/__snapshots__/AlertDialog.test.tsx.snap +551 -0
  15. package/dist/src/components/alert-dialog/index.ts +1 -0
  16. package/dist/src/components/autocomplete/Autocomplete.stories.tsx +70 -0
  17. package/dist/src/components/autocomplete/Autocomplete.test.tsx +181 -0
  18. package/dist/src/components/autocomplete/Autocomplete.tsx +292 -0
  19. package/dist/src/components/autocomplete/AutocompleteMultiple.stories.tsx +170 -0
  20. package/dist/src/components/autocomplete/AutocompleteMultiple.test.tsx +94 -0
  21. package/dist/src/components/autocomplete/AutocompleteMultiple.tsx +156 -0
  22. package/dist/src/components/autocomplete/__mockData__/index.ts +34 -0
  23. package/dist/src/components/autocomplete/__snapshots__/Autocomplete.test.tsx.snap +213 -0
  24. package/dist/src/components/autocomplete/__snapshots__/AutocompleteMultiple.test.tsx.snap +88 -0
  25. package/dist/src/components/autocomplete/index.ts +2 -0
  26. package/dist/src/components/avatar/Avatar.stories.tsx +92 -0
  27. package/dist/src/components/avatar/Avatar.test.tsx +39 -0
  28. package/dist/src/components/avatar/Avatar.tsx +112 -0
  29. package/dist/src/components/avatar/__snapshots__/Avatar.test.tsx.snap +681 -0
  30. package/dist/src/components/avatar/index.ts +1 -0
  31. package/dist/src/components/badge/Badge.stories.tsx +45 -0
  32. package/dist/src/components/badge/Badge.test.tsx +91 -0
  33. package/dist/src/components/badge/Badge.tsx +55 -0
  34. package/dist/src/components/badge/__snapshots__/Badge.test.tsx.snap +11 -0
  35. package/dist/src/components/badge/index.ts +1 -0
  36. package/dist/src/components/button/Button.stories.tsx +156 -0
  37. package/dist/src/components/button/Button.test.tsx +152 -0
  38. package/dist/src/components/button/Button.tsx +81 -0
  39. package/dist/src/components/button/ButtonGroup.test.tsx +66 -0
  40. package/dist/src/components/button/ButtonGroup.tsx +46 -0
  41. package/dist/src/components/button/ButtonRoot.test.tsx +203 -0
  42. package/dist/src/components/button/ButtonRoot.tsx +190 -0
  43. package/dist/src/components/button/IconButton.test.tsx +103 -0
  44. package/dist/src/components/button/IconButton.tsx +80 -0
  45. package/dist/src/components/button/__snapshots__/Button.test.tsx.snap +96 -0
  46. package/dist/src/components/button/__snapshots__/ButtonGroup.test.tsx.snap +22 -0
  47. package/dist/src/components/button/__snapshots__/ButtonRoot.test.tsx.snap +160 -0
  48. package/dist/src/components/button/__snapshots__/IconButton.test.tsx.snap +83 -0
  49. package/dist/src/components/button/index.ts +4 -0
  50. package/dist/src/components/checkbox/Checkbox.stories.tsx +37 -0
  51. package/dist/src/components/checkbox/Checkbox.test.tsx +114 -0
  52. package/dist/src/components/checkbox/Checkbox.tsx +145 -0
  53. package/dist/src/components/checkbox/__snapshots__/Checkbox.test.tsx.snap +141 -0
  54. package/dist/src/components/checkbox/index.ts +1 -0
  55. package/dist/src/components/chip/Chip.stories.tsx +21 -0
  56. package/dist/src/components/chip/Chip.test.tsx +199 -0
  57. package/dist/src/components/chip/Chip.tsx +154 -0
  58. package/dist/src/components/chip/ChipGroup.test.tsx +29 -0
  59. package/dist/src/components/chip/ChipGroup.tsx +62 -0
  60. package/dist/src/components/chip/__snapshots__/Chip.test.tsx.snap +12 -0
  61. package/dist/src/components/chip/__snapshots__/ChipGroup.test.tsx.snap +29 -0
  62. package/dist/src/components/chip/index.ts +2 -0
  63. package/dist/src/components/comment-block/CommentBlock.stories.tsx +30 -0
  64. package/dist/src/components/comment-block/CommentBlock.test.tsx +28 -0
  65. package/dist/src/components/comment-block/CommentBlock.tsx +174 -0
  66. package/dist/src/components/comment-block/__snapshots__/CommentBlock.test.tsx.snap +92 -0
  67. package/dist/src/components/comment-block/index.ts +1 -0
  68. package/dist/src/components/date-picker/DatePicker.test.tsx +41 -0
  69. package/dist/src/components/date-picker/DatePicker.tsx +56 -0
  70. package/dist/src/components/date-picker/DatePickerControlled.test.tsx +44 -0
  71. package/dist/src/components/date-picker/DatePickerControlled.tsx +128 -0
  72. package/dist/src/components/date-picker/DatePickerField.stories.tsx +93 -0
  73. package/dist/src/components/date-picker/DatePickerField.test.tsx +47 -0
  74. package/dist/src/components/date-picker/DatePickerField.tsx +141 -0
  75. package/dist/src/components/date-picker/__snapshots__/DatePicker.test.tsx.snap +22 -0
  76. package/dist/src/components/date-picker/__snapshots__/DatePickerControlled.test.tsx.snap +597 -0
  77. package/dist/src/components/date-picker/__snapshots__/DatePickerField.test.tsx.snap +43 -0
  78. package/dist/src/components/date-picker/constants.ts +11 -0
  79. package/dist/src/components/date-picker/index.ts +4 -0
  80. package/dist/src/components/date-picker/types.ts +28 -0
  81. package/dist/src/components/dialog/Dialog.stories.tsx +426 -0
  82. package/dist/src/components/dialog/Dialog.test.tsx +93 -0
  83. package/dist/src/components/dialog/Dialog.tsx +263 -0
  84. package/dist/src/components/dialog/__snapshots__/Dialog.test.tsx.snap +960 -0
  85. package/dist/src/components/dialog/index.ts +1 -0
  86. package/dist/src/components/divider/Divider.test.tsx +93 -0
  87. package/dist/src/components/divider/Divider.tsx +51 -0
  88. package/dist/src/components/divider/__snapshots__/Divider.test.tsx.snap +9 -0
  89. package/dist/src/components/divider/index.ts +1 -0
  90. package/dist/src/components/drag-handle/DragHandle.tsx +50 -0
  91. package/dist/src/components/drag-handle/index.ts +1 -0
  92. package/dist/src/components/dropdown/Dropdown.stories.tsx +216 -0
  93. package/dist/src/components/dropdown/Dropdown.test.tsx +97 -0
  94. package/dist/src/components/dropdown/Dropdown.tsx +184 -0
  95. package/dist/src/components/dropdown/__snapshots__/Dropdown.test.tsx.snap +35 -0
  96. package/dist/src/components/dropdown/index.ts +1 -0
  97. package/dist/src/components/expansion-panel/ExpansionPanel.test.tsx +116 -0
  98. package/dist/src/components/expansion-panel/ExpansionPanel.tsx +170 -0
  99. package/dist/src/components/expansion-panel/index.ts +1 -0
  100. package/dist/src/components/flag/Flag.stories.tsx +23 -0
  101. package/dist/src/components/flag/Flag.test.tsx +86 -0
  102. package/dist/src/components/flag/Flag.tsx +47 -0
  103. package/dist/src/components/flag/__snapshots__/Flag.test.tsx.snap +133 -0
  104. package/dist/src/components/flag/index.ts +1 -0
  105. package/dist/src/components/flex-box/FlexBox.stories.tsx +245 -0
  106. package/dist/src/components/flex-box/FlexBox.test.tsx +65 -0
  107. package/dist/src/components/flex-box/FlexBox.tsx +98 -0
  108. package/dist/src/components/flex-box/__snapshots__/FlexBox.test.tsx.snap +492 -0
  109. package/dist/src/components/flex-box/index.ts +1 -0
  110. package/dist/src/components/generic-block/GenericBlock.stories.jsx +128 -0
  111. package/dist/src/components/generic-block/GenericBlock.test.tsx +152 -0
  112. package/dist/src/components/generic-block/GenericBlock.tsx +222 -0
  113. package/dist/src/components/generic-block/constants.ts +9 -0
  114. package/dist/src/components/generic-block/index.ts +2 -0
  115. package/dist/src/components/grid/Grid.tsx +73 -0
  116. package/dist/src/components/grid/GridItem.tsx +54 -0
  117. package/dist/src/components/grid/index.ts +2 -0
  118. package/dist/src/components/grid-column/GridColumn.stories.jsx +56 -0
  119. package/dist/src/components/grid-column/GridColumn.test.jsx +58 -0
  120. package/dist/src/components/grid-column/GridColumn.tsx +90 -0
  121. package/dist/src/components/grid-column/index.ts +1 -0
  122. package/dist/src/components/heading/Heading.stories.tsx +108 -0
  123. package/dist/src/components/heading/Heading.test.tsx +82 -0
  124. package/dist/src/components/heading/Heading.tsx +63 -0
  125. package/dist/src/components/heading/HeadingLevelProvider.tsx +30 -0
  126. package/dist/src/components/heading/constants.ts +16 -0
  127. package/dist/src/components/heading/context.tsx +13 -0
  128. package/dist/src/components/heading/index.ts +3 -0
  129. package/dist/src/components/heading/useHeadingLevel.tsx +8 -0
  130. package/dist/src/components/icon/Icon.stories.tsx +76 -0
  131. package/dist/src/components/icon/Icon.test.tsx +102 -0
  132. package/dist/src/components/icon/Icon.tsx +121 -0
  133. package/dist/src/components/icon/__snapshots__/Icon.test.tsx.snap +49 -0
  134. package/dist/src/components/icon/index.ts +1 -0
  135. package/dist/src/components/image-block/ImageBlock.stories.tsx +52 -0
  136. package/dist/src/components/image-block/ImageBlock.test.tsx +28 -0
  137. package/dist/src/components/image-block/ImageBlock.tsx +151 -0
  138. package/dist/src/components/image-block/__snapshots__/ImageBlock.test.tsx.snap +64 -0
  139. package/dist/src/components/image-block/index.ts +1 -0
  140. package/dist/src/components/index.ts +176 -0
  141. package/dist/src/components/inline-list/InlineList.stories.tsx +40 -0
  142. package/dist/src/components/inline-list/InlineList.test.tsx +41 -0
  143. package/dist/src/components/inline-list/InlineList.tsx +82 -0
  144. package/dist/src/components/inline-list/index.ts +1 -0
  145. package/dist/src/components/input-helper/InputHelper.stories.tsx +29 -0
  146. package/dist/src/components/input-helper/InputHelper.test.tsx +107 -0
  147. package/dist/src/components/input-helper/InputHelper.tsx +61 -0
  148. package/dist/src/components/input-helper/__snapshots__/InputHelper.test.tsx.snap +9 -0
  149. package/dist/src/components/input-helper/constants.ts +11 -0
  150. package/dist/src/components/input-helper/index.ts +1 -0
  151. package/dist/src/components/input-label/InputLabel.stories.tsx +15 -0
  152. package/dist/src/components/input-label/InputLabel.test.tsx +86 -0
  153. package/dist/src/components/input-label/InputLabel.tsx +59 -0
  154. package/dist/src/components/input-label/__snapshots__/InputLabel.test.tsx.snap +10 -0
  155. package/dist/src/components/input-label/index.ts +1 -0
  156. package/dist/src/components/lightbox/Lightbox.stories.tsx +83 -0
  157. package/dist/src/components/lightbox/Lightbox.test.tsx +30 -0
  158. package/dist/src/components/lightbox/Lightbox.tsx +153 -0
  159. package/dist/src/components/lightbox/__snapshots__/Lightbox.test.tsx.snap +194 -0
  160. package/dist/src/components/lightbox/index.ts +1 -0
  161. package/dist/src/components/link/Link.stories.tsx +141 -0
  162. package/dist/src/components/link/Link.test.tsx +60 -0
  163. package/dist/src/components/link/Link.tsx +156 -0
  164. package/dist/src/components/link/__snapshots__/Link.test.tsx.snap +29 -0
  165. package/dist/src/components/link/index.ts +1 -0
  166. package/dist/src/components/link-preview/LinkPreview.stories.tsx +88 -0
  167. package/dist/src/components/link-preview/LinkPreview.test.tsx +102 -0
  168. package/dist/src/components/link-preview/LinkPreview.tsx +158 -0
  169. package/dist/src/components/link-preview/index.ts +1 -0
  170. package/dist/src/components/list/List.stories.tsx +141 -0
  171. package/dist/src/components/list/List.test.tsx +29 -0
  172. package/dist/src/components/list/List.tsx +94 -0
  173. package/dist/src/components/list/ListDivider.stories.tsx +7 -0
  174. package/dist/src/components/list/ListDivider.test.tsx +29 -0
  175. package/dist/src/components/list/ListDivider.tsx +42 -0
  176. package/dist/src/components/list/ListItem.stories.tsx +62 -0
  177. package/{src/components/progress/Progress.test.tsx → dist/src/components/list/ListItem.test.tsx} +8 -7
  178. package/dist/src/components/list/ListItem.tsx +154 -0
  179. package/dist/src/components/list/ListSubheader.stories.tsx +8 -0
  180. package/dist/src/components/list/ListSubheader.test.tsx +29 -0
  181. package/dist/src/components/list/ListSubheader.tsx +43 -0
  182. package/dist/src/components/list/__snapshots__/List.test.tsx.snap +360 -0
  183. package/dist/src/components/list/__snapshots__/ListDivider.test.tsx.snap +7 -0
  184. package/dist/src/components/list/__snapshots__/ListItem.test.tsx.snap +160 -0
  185. package/dist/src/components/list/__snapshots__/ListSubheader.test.tsx.snap +9 -0
  186. package/dist/src/components/list/index.ts +4 -0
  187. package/dist/src/components/list/useInteractiveList.tsx +202 -0
  188. package/dist/src/components/message/Message.stories.tsx +27 -0
  189. package/dist/src/components/message/Message.test.tsx +76 -0
  190. package/dist/src/components/message/Message.tsx +74 -0
  191. package/dist/src/components/message/__snapshots__/Message.test.tsx.snap +15 -0
  192. package/dist/src/components/message/index.ts +1 -0
  193. package/dist/src/components/mosaic/Mosaic.stories.tsx +85 -0
  194. package/dist/src/components/mosaic/Mosaic.test.tsx +120 -0
  195. package/dist/src/components/mosaic/Mosaic.tsx +95 -0
  196. package/dist/src/components/mosaic/__snapshots__/Mosaic.test.tsx.snap +357 -0
  197. package/dist/src/components/mosaic/index.ts +1 -0
  198. package/dist/src/components/notification/Notification.test.tsx +108 -0
  199. package/dist/src/components/notification/Notification.tsx +130 -0
  200. package/dist/src/components/notification/Notifications.stories.tsx +77 -0
  201. package/dist/src/components/notification/__snapshots__/Notification.test.tsx.snap +34 -0
  202. package/dist/src/components/notification/constants.ts +28 -0
  203. package/dist/src/components/notification/index.ts +1 -0
  204. package/dist/src/components/popover/Popover.stories.tsx +386 -0
  205. package/dist/src/components/popover/Popover.test.tsx +30 -0
  206. package/dist/src/components/popover/Popover.tsx +382 -0
  207. package/dist/src/components/popover/__snapshots__/Popover.test.tsx.snap +343 -0
  208. package/dist/src/components/popover/index.ts +1 -0
  209. package/dist/src/components/popover-dialog/PopoverDialog.stories.tsx +75 -0
  210. package/dist/src/components/popover-dialog/PopoverDialog.test.tsx +65 -0
  211. package/dist/src/components/popover-dialog/PopoverDialog.tsx +65 -0
  212. package/dist/src/components/popover-dialog/index.tsx +1 -0
  213. package/dist/src/components/post-block/PostBlock.test.tsx +28 -0
  214. package/dist/src/components/post-block/PostBlock.tsx +123 -0
  215. package/dist/src/components/post-block/__snapshots__/PostBlock.test.tsx.snap +139 -0
  216. package/dist/src/components/post-block/index.ts +1 -0
  217. package/dist/src/components/progress/Progress.tsx +68 -0
  218. package/dist/src/components/progress/ProgressCircular.stories.tsx +18 -0
  219. package/dist/src/components/progress/ProgressCircular.test.tsx +49 -0
  220. package/dist/src/components/progress/ProgressCircular.tsx +68 -0
  221. package/dist/src/components/progress/ProgressLinear.stories.tsx +8 -0
  222. package/dist/src/components/progress/ProgressLinear.test.tsx +37 -0
  223. package/dist/src/components/progress/ProgressLinear.tsx +52 -0
  224. package/dist/src/components/progress/index.ts +3 -0
  225. package/dist/src/components/progress-tracker/ProgressTracker.stories.tsx +145 -0
  226. package/dist/src/components/progress-tracker/ProgressTracker.test.tsx +57 -0
  227. package/dist/src/components/progress-tracker/ProgressTracker.tsx +89 -0
  228. package/dist/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +42 -0
  229. package/dist/src/components/progress-tracker/ProgressTrackerProvider.tsx +66 -0
  230. package/dist/src/components/progress-tracker/ProgressTrackerStep.test.tsx +128 -0
  231. package/dist/src/components/progress-tracker/ProgressTrackerStep.tsx +159 -0
  232. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +73 -0
  233. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +67 -0
  234. package/dist/src/components/progress-tracker/__snapshots__/ProgressTracker.test.tsx.snap +41 -0
  235. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStep.test.tsx.snap +141 -0
  236. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStepPanel.test.tsx.snap +25 -0
  237. package/dist/src/components/progress-tracker/index.ts +4 -0
  238. package/dist/src/components/radio-button/RadioButton.stories.tsx +28 -0
  239. package/dist/src/components/radio-button/RadioButton.test.tsx +123 -0
  240. package/dist/src/components/radio-button/RadioButton.tsx +141 -0
  241. package/dist/src/components/radio-button/RadioGroup.stories.tsx +42 -0
  242. package/dist/src/components/radio-button/RadioGroup.test.tsx +77 -0
  243. package/dist/src/components/radio-button/RadioGroup.tsx +52 -0
  244. package/dist/src/components/radio-button/__snapshots__/RadioButton.test.tsx.snap +113 -0
  245. package/dist/src/components/radio-button/__snapshots__/RadioGroup.test.tsx.snap +26 -0
  246. package/dist/src/components/radio-button/index.ts +2 -0
  247. package/dist/src/components/select/Select.stories.tsx +399 -0
  248. package/dist/src/components/select/Select.test.tsx +359 -0
  249. package/dist/src/components/select/Select.tsx +193 -0
  250. package/dist/src/components/select/SelectMultiple.stories.tsx +227 -0
  251. package/dist/src/components/select/SelectMultiple.test.tsx +405 -0
  252. package/dist/src/components/select/SelectMultiple.tsx +198 -0
  253. package/dist/src/components/select/WithSelectContext.tsx +143 -0
  254. package/dist/src/components/select/__snapshots__/Select.test.tsx.snap +43 -0
  255. package/dist/src/components/select/__snapshots__/SelectMultiple.test.tsx.snap +87 -0
  256. package/dist/src/components/select/constants.ts +53 -0
  257. package/dist/src/components/select/index.ts +2 -0
  258. package/dist/src/components/side-navigation/SideNavigation.stories.tsx +191 -0
  259. package/dist/src/components/side-navigation/SideNavigation.test.tsx +52 -0
  260. package/dist/src/components/side-navigation/SideNavigation.tsx +54 -0
  261. package/dist/src/components/side-navigation/SideNavigationItem.test.tsx +175 -0
  262. package/dist/src/components/side-navigation/SideNavigationItem.tsx +162 -0
  263. package/dist/src/components/side-navigation/__snapshots__/SideNavigation.test.tsx.snap +7 -0
  264. package/dist/src/components/side-navigation/__snapshots__/SideNavigationItem.test.tsx.snap +30 -0
  265. package/dist/src/components/side-navigation/index.ts +2 -0
  266. package/dist/src/components/skeleton/SkeletonCircle.stories.tsx +25 -0
  267. package/dist/src/components/skeleton/SkeletonCircle.test.tsx +28 -0
  268. package/dist/src/components/skeleton/SkeletonCircle.tsx +52 -0
  269. package/dist/src/components/skeleton/SkeletonRectangle.stories.tsx +107 -0
  270. package/dist/src/components/skeleton/SkeletonRectangle.test.tsx +28 -0
  271. package/dist/src/components/skeleton/SkeletonRectangle.tsx +78 -0
  272. package/dist/src/components/skeleton/SkeletonTypography.stories.tsx +26 -0
  273. package/dist/src/components/skeleton/SkeletonTypography.test.tsx +28 -0
  274. package/dist/src/components/skeleton/SkeletonTypography.tsx +57 -0
  275. package/dist/src/components/skeleton/__snapshots__/SkeletonCircle.test.tsx.snap +54 -0
  276. package/dist/src/components/skeleton/__snapshots__/SkeletonRectangle.test.tsx.snap +177 -0
  277. package/dist/src/components/skeleton/__snapshots__/SkeletonTypography.test.tsx.snap +174 -0
  278. package/dist/src/components/skeleton/index.ts +3 -0
  279. package/dist/src/components/slider/Slider.stories.tsx +29 -0
  280. package/dist/src/components/slider/Slider.test.tsx +31 -0
  281. package/dist/src/components/slider/Slider.tsx +299 -0
  282. package/dist/src/components/slider/__snapshots__/Slider.test.tsx.snap +122 -0
  283. package/dist/src/components/slider/index.ts +2 -0
  284. package/dist/src/components/slideshow/Slides.tsx +124 -0
  285. package/dist/src/components/slideshow/Slideshow.stories.tsx +212 -0
  286. package/dist/src/components/slideshow/Slideshow.test.tsx +39 -0
  287. package/dist/src/components/slideshow/Slideshow.tsx +170 -0
  288. package/dist/src/components/slideshow/SlideshowControls.stories.tsx +112 -0
  289. package/dist/src/components/slideshow/SlideshowControls.tsx +241 -0
  290. package/dist/src/components/slideshow/SlideshowItem.tsx +52 -0
  291. package/dist/src/components/slideshow/SlideshowItemGroup.tsx +64 -0
  292. package/dist/src/components/slideshow/__snapshots__/Slideshow.test.tsx.snap +157 -0
  293. package/dist/src/components/slideshow/constants.ts +24 -0
  294. package/dist/src/components/slideshow/index.ts +4 -0
  295. package/dist/src/components/slideshow/useKeyNavigate.ts +28 -0
  296. package/dist/src/components/slideshow/usePaginationVisibleRange.ts +37 -0
  297. package/dist/src/components/slideshow/useSlideFocusManagement.tsx +92 -0
  298. package/dist/src/components/slideshow/useSwipeNavigate.ts +18 -0
  299. package/dist/src/components/switch/Switch.stories.tsx +36 -0
  300. package/dist/src/components/switch/Switch.test.tsx +189 -0
  301. package/dist/src/components/switch/Switch.tsx +141 -0
  302. package/dist/src/components/switch/__snapshots__/Switch.test.tsx.snap +179 -0
  303. package/dist/src/components/switch/index.ts +1 -0
  304. package/dist/src/components/table/Table.test.tsx +28 -0
  305. package/dist/src/components/table/Table.tsx +59 -0
  306. package/dist/src/components/table/TableBody.test.tsx +22 -0
  307. package/dist/src/components/table/TableBody.tsx +44 -0
  308. package/dist/src/components/table/TableCell.test.tsx +23 -0
  309. package/dist/src/components/table/TableCell.tsx +125 -0
  310. package/dist/src/components/table/TableHeader.test.tsx +22 -0
  311. package/dist/src/components/table/TableHeader.tsx +50 -0
  312. package/dist/src/components/table/TableRow.test.tsx +22 -0
  313. package/dist/src/components/table/TableRow.tsx +68 -0
  314. package/dist/src/components/table/__snapshots__/Table.test.tsx.snap +263 -0
  315. package/dist/src/components/table/index.ts +5 -0
  316. package/dist/src/components/tabs/Tab.test.tsx +116 -0
  317. package/dist/src/components/tabs/Tab.tsx +120 -0
  318. package/dist/src/components/tabs/TabList.test.tsx +80 -0
  319. package/dist/src/components/tabs/TabList.tsx +82 -0
  320. package/dist/src/components/tabs/TabPanel.test.tsx +74 -0
  321. package/dist/src/components/tabs/TabPanel.tsx +65 -0
  322. package/dist/src/components/tabs/TabProvider.test.tsx +42 -0
  323. package/dist/src/components/tabs/TabProvider.tsx +59 -0
  324. package/dist/src/components/tabs/Tabs.stories.tsx +134 -0
  325. package/dist/src/components/tabs/__snapshots__/Tab.test.tsx.snap +62 -0
  326. package/dist/src/components/tabs/__snapshots__/TabList.test.tsx.snap +22 -0
  327. package/dist/src/components/tabs/__snapshots__/TabPanel.test.tsx.snap +25 -0
  328. package/dist/src/components/tabs/index.ts +4 -0
  329. package/dist/src/components/tabs/state.ts +116 -0
  330. package/dist/src/components/tabs/test.mocks.ts +33 -0
  331. package/dist/src/components/text/Text.stories.jsx +75 -0
  332. package/dist/src/components/text/Text.test.tsx +108 -0
  333. package/dist/src/components/text/Text.tsx +121 -0
  334. package/dist/src/components/text/index.ts +1 -0
  335. package/dist/src/components/text-field/TextField.stories.tsx +169 -0
  336. package/dist/src/components/text-field/TextField.test.tsx +171 -0
  337. package/dist/src/components/text-field/TextField.tsx +432 -0
  338. package/dist/src/components/text-field/__snapshots__/TextField.test.tsx.snap +42 -0
  339. package/dist/src/components/text-field/index.ts +1 -0
  340. package/dist/src/components/thumbnail/Thumbnail.stories.tsx +510 -0
  341. package/dist/src/components/thumbnail/Thumbnail.test.tsx +46 -0
  342. package/dist/src/components/thumbnail/Thumbnail.tsx +222 -0
  343. package/dist/src/components/thumbnail/__snapshots__/Thumbnail.test.tsx.snap +130 -0
  344. package/dist/src/components/thumbnail/index.ts +3 -0
  345. package/dist/src/components/thumbnail/types.ts +39 -0
  346. package/dist/src/components/thumbnail/useFocusPointStyle.test.ts +92 -0
  347. package/dist/src/components/thumbnail/useFocusPointStyle.tsx +111 -0
  348. package/dist/src/components/thumbnail/useImageLoad.ts +40 -0
  349. package/dist/src/components/toolbar/Toolbar.tsx +67 -0
  350. package/dist/src/components/toolbar/index.ts +1 -0
  351. package/dist/src/components/tooltip/Tooltip.stories.tsx +172 -0
  352. package/dist/src/components/tooltip/Tooltip.test.tsx +105 -0
  353. package/dist/src/components/tooltip/Tooltip.tsx +122 -0
  354. package/dist/src/components/tooltip/__snapshots__/Tooltip.test.tsx.snap +233 -0
  355. package/dist/src/components/tooltip/index.ts +1 -0
  356. package/dist/src/components/tooltip/useInjectTooltipRef.tsx +44 -0
  357. package/dist/src/components/tooltip/useTooltipOpen.tsx +113 -0
  358. package/dist/src/components/uploader/Uploader.test.tsx +87 -0
  359. package/dist/src/components/uploader/Uploader.tsx +105 -0
  360. package/dist/src/components/uploader/__snapshots__/Uploader.test.tsx.snap +14 -0
  361. package/dist/src/components/uploader/index.ts +1 -0
  362. package/dist/src/components/user-block/UserBlock.stories.tsx +76 -0
  363. package/dist/src/components/user-block/UserBlock.test.tsx +38 -0
  364. package/dist/src/components/user-block/UserBlock.tsx +179 -0
  365. package/dist/src/components/user-block/__snapshots__/UserBlock.test.tsx.snap +362 -0
  366. package/dist/src/components/user-block/index.ts +1 -0
  367. package/dist/src/constants.ts +17 -0
  368. package/dist/src/hooks/useBooleanState.tsx +13 -0
  369. package/dist/src/hooks/useCallbackOnEscape.ts +34 -0
  370. package/dist/src/hooks/useChipGroupNavigation.tsx +75 -0
  371. package/dist/src/hooks/useClickAway.tsx +47 -0
  372. package/dist/src/hooks/useDisableBodyScroll.ts +28 -0
  373. package/dist/src/hooks/useEventCallback.tsx +17 -0
  374. package/dist/src/hooks/useFocus.tsx +21 -0
  375. package/dist/src/hooks/useFocusTrap.ts +85 -0
  376. package/dist/src/hooks/useFocusWithin.ts +33 -0
  377. package/dist/src/hooks/useInfiniteScroll.tsx +60 -0
  378. package/dist/src/hooks/useIntersectionObserver.tsx +43 -0
  379. package/dist/src/hooks/useInterval.tsx +31 -0
  380. package/dist/src/hooks/useKeyboardListNavigation.tsx +204 -0
  381. package/dist/src/hooks/useListenFocus.tsx +26 -0
  382. package/dist/src/hooks/useOnResize.ts +41 -0
  383. package/dist/src/hooks/useRovingTabIndex.tsx +90 -0
  384. package/dist/src/hooks/useSlideshowControls.ts +243 -0
  385. package/dist/src/hooks/useStopPropagation.ts +21 -0
  386. package/dist/src/hooks/useTransitionVisibility.ts +54 -0
  387. package/dist/src/index.ts +58 -0
  388. package/dist/src/stories/chromaticForceScreenSize.tsx +7 -0
  389. package/dist/src/stories/generated/Autocomplete/Demos.stories.tsx +7 -0
  390. package/dist/src/stories/generated/Avatar/Demos.stories.tsx +7 -0
  391. package/dist/src/stories/generated/Badge/Demos.stories.tsx +9 -0
  392. package/dist/src/stories/generated/Button/Demos.stories.tsx +11 -0
  393. package/dist/src/stories/generated/Checkbox/Demos.stories.tsx +6 -0
  394. package/dist/src/stories/generated/Chip/Demos.stories.tsx +11 -0
  395. package/dist/src/stories/generated/CommentBlock/Demos.stories.tsx +8 -0
  396. package/dist/src/stories/generated/DatePicker/Demos.stories.tsx +8 -0
  397. package/dist/src/stories/generated/Dialog/Demos.stories.tsx +10 -0
  398. package/dist/src/stories/generated/Divider/Demos.stories.tsx +6 -0
  399. package/dist/src/stories/generated/Dropdown/Demos.stories.tsx +8 -0
  400. package/dist/src/stories/generated/ExpansionPanel/Demos.stories.tsx +9 -0
  401. package/dist/src/stories/generated/Flag/Demos.stories.tsx +6 -0
  402. package/dist/src/stories/generated/GenericBlock/Demos.stories.tsx +8 -0
  403. package/dist/src/stories/generated/Heading/Demos.stories.tsx +6 -0
  404. package/dist/src/stories/generated/Icon/Demos.stories.tsx +8 -0
  405. package/dist/src/stories/generated/ImageBlock/Demos.stories.tsx +9 -0
  406. package/dist/src/stories/generated/Lightbox/Demos.stories.tsx +6 -0
  407. package/dist/src/stories/generated/Link/Demos.stories.tsx +8 -0
  408. package/dist/src/stories/generated/LinkPreview/Demos.stories.tsx +7 -0
  409. package/dist/src/stories/generated/List/Demos.stories.tsx +11 -0
  410. package/dist/src/stories/generated/Message/Demos.stories.tsx +10 -0
  411. package/dist/src/stories/generated/Mosaic/Demos.stories.tsx +9 -0
  412. package/dist/src/stories/generated/Notification/Demos.stories.tsx +6 -0
  413. package/dist/src/stories/generated/Popover/Demos.stories.tsx +11 -0
  414. package/dist/src/stories/generated/PopoverDialog/Demos.stories.tsx +6 -0
  415. package/dist/src/stories/generated/PostBlock/Demos.stories.tsx +6 -0
  416. package/dist/src/stories/generated/Progress/Demos.stories.tsx +7 -0
  417. package/dist/src/stories/generated/ProgressTracker/Demos.stories.tsx +9 -0
  418. package/dist/src/stories/generated/RadioButton/Demos.stories.tsx +6 -0
  419. package/dist/src/stories/generated/Select/Demos.stories.tsx +14 -0
  420. package/dist/src/stories/generated/SideNavigation/Demos.stories.tsx +10 -0
  421. package/dist/src/stories/generated/Skeleton/Demos.stories.tsx +9 -0
  422. package/dist/src/stories/generated/Slider/Demos.stories.tsx +9 -0
  423. package/dist/src/stories/generated/Slideshow/Demos.stories.tsx +8 -0
  424. package/dist/src/stories/generated/Switch/Demos.stories.tsx +6 -0
  425. package/dist/src/stories/generated/Table/Demos.stories.tsx +6 -0
  426. package/dist/src/stories/generated/Tabs/Demos.stories.tsx +8 -0
  427. package/dist/src/stories/generated/TextField/Demos.stories.tsx +19 -0
  428. package/dist/src/stories/generated/Thumbnail/Demos.stories.tsx +12 -0
  429. package/dist/src/stories/generated/Toolbar/Demos.stories.tsx +10 -0
  430. package/dist/src/stories/generated/Tooltip/Demos.stories.tsx +8 -0
  431. package/dist/src/stories/generated/Uploader/Demos.stories.tsx +8 -0
  432. package/dist/src/stories/generated/UserBlock/Demos.stories.tsx +10 -0
  433. package/dist/src/stories/knobs/buttonKnob.ts +9 -0
  434. package/dist/src/stories/knobs/emphasisKnob.ts +8 -0
  435. package/dist/src/stories/knobs/enumKnob.ts +14 -0
  436. package/dist/src/stories/knobs/focusKnob.ts +3 -0
  437. package/dist/src/stories/knobs/image.ts +69 -0
  438. package/dist/src/stories/knobs/lorem.ts +59 -0
  439. package/dist/src/stories/knobs/sizeKnob.ts +5 -0
  440. package/dist/src/stories/knobs/thumbnailsKnob.ts +9 -0
  441. package/dist/src/stories/utils/CustomLink.tsx +7 -0
  442. package/dist/src/stories/withResizableBox.tsx +18 -0
  443. package/dist/src/testing/utils/commonTestsSuite.ts +71 -0
  444. package/dist/src/testing/utils/commonTestsSuiteRTL.ts +55 -0
  445. package/dist/src/testing/utils/index.ts +4 -0
  446. package/dist/src/testing/utils/itShouldRenderStories.tsx +103 -0
  447. package/dist/src/testing/utils/queries.ts +19 -0
  448. package/dist/src/untypped-modules.d.ts +7 -0
  449. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +58 -0
  450. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +65 -0
  451. package/dist/src/utils/ClickAwayProvider/index.ts +1 -0
  452. package/dist/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +54 -0
  453. package/dist/src/utils/MaterialThemeSwitcher/index.ts +1 -0
  454. package/dist/src/utils/browserDoesNotSupportHover.test.js +24 -0
  455. package/dist/src/utils/browserDoesNotSupportHover.ts +2 -0
  456. package/dist/src/utils/clamp.ts +17 -0
  457. package/dist/src/utils/className.ts +44 -0
  458. package/dist/src/utils/event.ts +1 -0
  459. package/dist/src/utils/flattenChildren.test.tsx +58 -0
  460. package/dist/src/utils/flattenChildren.ts +27 -0
  461. package/dist/src/utils/focus/constants.ts +5 -0
  462. package/dist/src/utils/focus/getFirstAndLastFocusable.test.ts +134 -0
  463. package/dist/src/utils/focus/getFirstAndLastFocusable.ts +21 -0
  464. package/dist/src/utils/focus/getFocusableElements.test.ts +151 -0
  465. package/dist/src/utils/focus/getFocusableElements.ts +7 -0
  466. package/dist/src/utils/index.ts +5 -0
  467. package/dist/src/utils/isInternetExplorer.ts +15 -0
  468. package/dist/src/utils/makeListenerTowerContext.ts +32 -0
  469. package/dist/src/utils/mergeRefs.ts +22 -0
  470. package/dist/src/utils/partitionMulti.ts +28 -0
  471. package/dist/src/utils/renderLink.tsx +17 -0
  472. package/dist/src/utils/type.ts +113 -0
  473. package/dist/src/utils/userHasReducedMotion.ts +7 -0
  474. package/dist/src/utils/utils.test.ts +48 -0
  475. package/{utils → dist/utils}/index.d.ts +0 -0
  476. package/{utils → dist/utils}/index.js +0 -0
  477. package/{utils → dist/utils}/index.js.map +0 -0
  478. package/jest/__mocks__/@storybook/addon-actions.js +3 -0
  479. package/jest/__mocks__/@storybook/addon-knobs.js +6 -0
  480. package/jest/__mocks__/emptyFileMockTransformer.js +8 -0
  481. package/jest/__mocks__/emptyModuleMock.js +1 -0
  482. package/jest/configure.js +6 -0
  483. package/jest/index.js +36 -0
  484. package/jest/transform.js +6 -0
  485. package/package.json +3 -5
  486. package/rollup.config.js +98 -0
  487. package/src/components/badge/Badge.tsx +2 -2
  488. package/src/components/button/ButtonRoot.tsx +2 -2
  489. package/src/components/chip/Chip.tsx +2 -2
  490. package/src/components/grid-column/GridColumn.stories.jsx +56 -0
  491. package/src/components/grid-column/GridColumn.test.jsx +58 -0
  492. package/src/components/grid-column/GridColumn.tsx +90 -0
  493. package/src/components/grid-column/index.ts +1 -0
  494. package/src/components/icon/Icon.tsx +2 -2
  495. package/src/components/link/Link.tsx +2 -2
  496. package/src/components/progress/Progress.tsx +6 -25
  497. package/src/components/progress/ProgressCircular.stories.tsx +18 -0
  498. package/src/components/progress/ProgressCircular.test.tsx +49 -0
  499. package/src/components/progress/ProgressCircular.tsx +68 -0
  500. package/src/components/progress/ProgressLinear.stories.tsx +8 -0
  501. package/src/components/progress/ProgressLinear.test.tsx +37 -0
  502. package/src/components/progress/ProgressLinear.tsx +52 -0
  503. package/src/components/progress/index.ts +2 -0
  504. package/src/index.ts +1 -0
  505. package/storybook/build +4 -0
  506. package/storybook/generate-demo-stories.js +59 -0
  507. package/storybook/main.js +67 -0
  508. package/storybook/package.json +13 -0
  509. package/storybook/preview.js +11 -0
  510. package/storybook/start +4 -0
  511. package/storybook/story-block/StoryBlock.tsx +49 -0
  512. package/storybook/story-block/decorator.jsx +7 -0
  513. package/storybook/story-block/index.scss +27 -0
  514. package/storybook/yarn.lock +13192 -0
  515. package/tsconfig.json +3 -0
  516. package/index.js.map +0 -1
  517. package/src/components/progress/__snapshots__/Progress.test.tsx.snap +0 -48
@@ -0,0 +1,151 @@
1
+ import { getFocusableElements } from '@lumx/react/utils/focus/getFocusableElements';
2
+
3
+ function htmlToElement(html: string): any {
4
+ const template = document.createElement('template');
5
+ template.innerHTML = html.trim();
6
+ return template.content.firstChild;
7
+ }
8
+
9
+ describe(getFocusableElements.name, () => {
10
+ it('should get empty', () => {
11
+ const element = htmlToElement(`<div></div>`);
12
+ const focusable = getFocusableElements(element);
13
+ expect(focusable).toEqual([]);
14
+ });
15
+
16
+ it('should get single item', () => {
17
+ const element = htmlToElement(`<div><button /></div>`);
18
+ const focusable = getFocusableElements(element);
19
+ expect(focusable).toMatchInlineSnapshot(`
20
+ [
21
+ <button />,
22
+ ]
23
+ `);
24
+ });
25
+
26
+ describe('match focusable elements', () => {
27
+ it('should match input element', () => {
28
+ const element = htmlToElement(`<div><input /></div>`);
29
+ const focusable = getFocusableElements(element);
30
+ expect(focusable).toMatchInlineSnapshot(`
31
+ [
32
+ <input />,
33
+ ]
34
+ `);
35
+ });
36
+
37
+ it('should match link element', () => {
38
+ const element = htmlToElement(`<div><a href="#" /></div>`);
39
+ const focusable = getFocusableElements(element);
40
+ expect(focusable).toMatchInlineSnapshot(`
41
+ [
42
+ <a
43
+ href="#"
44
+ />,
45
+ ]
46
+ `);
47
+ });
48
+
49
+ it('should match textarea element', () => {
50
+ const element = htmlToElement(`<div><textarea /></div>`);
51
+ const focusable = getFocusableElements(element);
52
+ expect(focusable).toMatchInlineSnapshot(`
53
+ [
54
+ <textarea>
55
+ &lt;/div&gt;
56
+ </textarea>,
57
+ ]
58
+ `);
59
+ });
60
+
61
+ it('should match element with tabindex', () => {
62
+ const element = htmlToElement(`<div><span tabindex="0" /></div>`);
63
+ const focusable = getFocusableElements(element);
64
+ expect(focusable).toMatchInlineSnapshot(`
65
+ [
66
+ <span
67
+ tabindex="0"
68
+ />,
69
+ ]
70
+ `);
71
+ });
72
+
73
+ it('should keep disabled=false', () => {
74
+ const element = htmlToElement(`<div><button disabled="false" /><button /></div>`);
75
+ const focusable = getFocusableElements(element);
76
+ expect(focusable).toMatchInlineSnapshot(`
77
+ [
78
+ <button
79
+ disabled="false"
80
+ />,
81
+ <button />,
82
+ ]
83
+ `);
84
+ });
85
+
86
+ it('should keep aria-disabled=false', () => {
87
+ const element = htmlToElement(`<div><button aria-disabled="false" /><button /></div>`);
88
+ const focusable = getFocusableElements(element);
89
+ expect(focusable).toMatchInlineSnapshot(`
90
+ [
91
+ <button
92
+ aria-disabled="false"
93
+ />,
94
+ <button />,
95
+ ]
96
+ `);
97
+ });
98
+ });
99
+
100
+ describe('skip disabled elements', () => {
101
+ it('should skip disabled', () => {
102
+ const element = htmlToElement(`<div><button disabled /><button /></div>`);
103
+ const focusable = getFocusableElements(element);
104
+ expect(focusable).toMatchInlineSnapshot(`
105
+ [
106
+ <button />,
107
+ ]
108
+ `);
109
+ });
110
+
111
+ it('should skip aria-disabled', () => {
112
+ const element = htmlToElement(`<div><button aria-disabled /><button /></div>`);
113
+ const focusable = getFocusableElements(element);
114
+ expect(focusable).toMatchInlineSnapshot(`
115
+ [
116
+ <button />,
117
+ ]
118
+ `);
119
+ });
120
+
121
+ it('should skip tabindex=-1', () => {
122
+ const element = htmlToElement(`<div><button tabindex="-1" /><button /></div>`);
123
+ const focusable = getFocusableElements(element);
124
+ expect(focusable).toMatchInlineSnapshot(`
125
+ [
126
+ <button />,
127
+ ]
128
+ `);
129
+ });
130
+
131
+ it('should skip input type hidden', () => {
132
+ const element = htmlToElement(`<div><input type="hidden" /><button /></div>`);
133
+ const focusable = getFocusableElements(element);
134
+ expect(focusable).toMatchInlineSnapshot(`
135
+ [
136
+ <button />,
137
+ ]
138
+ `);
139
+ });
140
+
141
+ it('should skip hidden input', () => {
142
+ const element = htmlToElement(`<div><input hidden /><button /></div>`);
143
+ const focusable = getFocusableElements(element);
144
+ expect(focusable).toMatchInlineSnapshot(`
145
+ [
146
+ <button />,
147
+ ]
148
+ `);
149
+ });
150
+ });
151
+ });
@@ -0,0 +1,7 @@
1
+ import { DISABLED_SELECTOR, TABBABLE_ELEMENTS_SELECTOR } from './constants';
2
+
3
+ const isNotDisabled = (element: HTMLElement) => !element.matches(DISABLED_SELECTOR);
4
+
5
+ export function getFocusableElements(element: HTMLElement): HTMLElement[] {
6
+ return Array.from(element.querySelectorAll<HTMLElement>(TABBABLE_ELEMENTS_SELECTOR)).filter(isNotDisabled);
7
+ }
@@ -0,0 +1,5 @@
1
+ /**
2
+ * WARNING: All modules exported here are exposed to NPM in '@lumx/react/utils'.
3
+ */
4
+
5
+ export * from './ClickAwayProvider';
@@ -0,0 +1,15 @@
1
+ import { WINDOW } from '@lumx/react/constants';
2
+
3
+ /**
4
+ * Check if browser is IE
5
+ * @return Browser is IE or not
6
+ */
7
+ export const isInternetExplorer = () => {
8
+ const userAgent = WINDOW?.navigator?.userAgent;
9
+ if (!userAgent) {
10
+ return false;
11
+ }
12
+ const msie = userAgent.indexOf('MSIE ');
13
+ const isIEVersion = !!userAgent.match(/Trident.*rv:11\./);
14
+ return msie > 0 || isIEVersion;
15
+ };
@@ -0,0 +1,32 @@
1
+ import last from 'lodash/last';
2
+ import pull from 'lodash/pull';
3
+
4
+ export type Listener = { enable(): void; disable(): void };
5
+
6
+ /**
7
+ * Keep track of listeners, only the last registered listener gets activated at any point (previously registered
8
+ * listener are disabled).
9
+ * When a listener gets unregistered, the previously registered listener gets enabled again.
10
+ */
11
+ export function makeListenerTowerContext() {
12
+ const LISTENERS: Listener[] = [];
13
+
14
+ return {
15
+ register(listener: Listener) {
16
+ // Disable previous listener.
17
+ last(LISTENERS)?.disable();
18
+ // Keep track of current listener.
19
+ LISTENERS.push(listener);
20
+ // Enable current listener.
21
+ listener.enable();
22
+ },
23
+ unregister(listener: Listener) {
24
+ // Disable current listener.
25
+ listener.disable();
26
+ // Remove current listener.
27
+ pull(LISTENERS, listener);
28
+ // Enable previous listener.
29
+ last(LISTENERS)?.enable();
30
+ },
31
+ };
32
+ }
@@ -0,0 +1,22 @@
1
+ import { Falsy } from '@lumx/react/utils/type';
2
+ import { MutableRefObject } from 'react';
3
+
4
+ type FnRef<T> = (value: T) => void;
5
+
6
+ /**
7
+ * Merge refs into a single function ref.
8
+ *
9
+ * @param refs React references to merge.
10
+ * @return the merged ref.
11
+ */
12
+ export function mergeRefs<T>(...refs: Array<MutableRefObject<T | null> | FnRef<T> | Falsy>): FnRef<T> {
13
+ return (value) =>
14
+ refs.forEach((ref) => {
15
+ if (typeof ref === 'function') {
16
+ ref(value);
17
+ } else if (ref) {
18
+ // eslint-disable-next-line no-param-reassign
19
+ (ref as MutableRefObject<T>).current = value;
20
+ }
21
+ });
22
+ }
@@ -0,0 +1,28 @@
1
+ import concat from 'lodash/concat';
2
+ import dropRight from 'lodash/dropRight';
3
+ import last from 'lodash/last';
4
+ import partition from 'lodash/partition';
5
+ import reduce from 'lodash/reduce';
6
+ import { Predicate } from './type';
7
+
8
+ /**
9
+ * Similar to lodash `partition` function but working with multiple predicates.
10
+ *
11
+ * @example
12
+ * const isString = (s) => typeof s === 'string'
13
+ * const isNumber = (s) => typeof s === 'number'
14
+ * const [strings, numbers, others] = partitionMulti(['a', 1, 'b', false], [isString, isNumber])
15
+ * //=> [['a', 'b'], [1], [false]]
16
+ *
17
+ * @param elements array of elements
18
+ * @param predicates array of predicates to apply on elements
19
+ * @return partitioned elements by the given predicates
20
+ */
21
+ export function partitionMulti<T>(elements: T[], predicates: Array<Predicate<T>>): T[][] {
22
+ return reduce(
23
+ predicates,
24
+ (partitioned: T[][], predicate: Predicate<T>) =>
25
+ concat(dropRight(partitioned), partition(last(partitioned), predicate)),
26
+ [elements],
27
+ );
28
+ }
@@ -0,0 +1,17 @@
1
+ import React, { ReactElement, ReactNode } from 'react';
2
+
3
+ interface Props {
4
+ linkAs: any;
5
+ }
6
+
7
+ /**
8
+ * Render link with default <a> HTML component or a custom one provided by `linkAs`.
9
+ *
10
+ * Can be used to inject the `Link` component from `react-router` and provide better a11y on LumX components.
11
+ *
12
+ * @param linkAs Custom link component.
13
+ * @param children Link children.
14
+ * @return A link.
15
+ */
16
+ export const renderLink = <P extends Props>({ linkAs, ...forwardedProps }: P, ...children: ReactNode[]): ReactElement =>
17
+ React.createElement(linkAs || 'a', forwardedProps, ...children);
@@ -0,0 +1,113 @@
1
+ import get from 'lodash/get';
2
+ import React, { ReactElement, ReactNode, Ref } from 'react';
3
+ import { Theme } from '@lumx/react';
4
+
5
+ /** Get types of the values of a record. */
6
+ export type ValueOf<T extends Record<any, any>> = T[keyof T];
7
+
8
+ /**
9
+ * Properties of a component to use to determine it's name.
10
+ * In the order of preference.
11
+ */
12
+ const NAME_PROPERTIES: string[] = [
13
+ 'type',
14
+ 'type.displayName',
15
+ 'displayName',
16
+ 'name',
17
+ 'type.name',
18
+ 'props.mdxType',
19
+ '_reactInternalFiber.elementType.name',
20
+ ];
21
+
22
+ /** LumX Component Type. */
23
+ export type Comp<P, T = HTMLElement> = {
24
+ (props: P & { ref?: Ref<T> }): ReactElement | null;
25
+ /** React component type. */
26
+ readonly $$typeof: symbol;
27
+ /** Component default props. */
28
+ defaultProps?: Partial<P>;
29
+ /** Component name. */
30
+ displayName?: string;
31
+ /** Component base class name. */
32
+ className?: string;
33
+ };
34
+
35
+ /** Union type of all heading elements */
36
+ export type HeadingElement = 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';
37
+
38
+ /** Union type of all text elements */
39
+ export type TextElement = 'span' | 'p' | HeadingElement;
40
+
41
+ export interface HasTheme {
42
+ /**
43
+ * Theme adapting the component to light or dark background.
44
+ */
45
+ theme?: Theme;
46
+ }
47
+
48
+ /**
49
+ * Define a generic props types.
50
+ */
51
+ export interface GenericProps {
52
+ /**
53
+ * Class name forwarded to the root element of the component.
54
+ */
55
+ className?: string;
56
+ /**
57
+ * Any prop (particularly any supported prop for a HTML element).
58
+ */
59
+ [propName: string]: any;
60
+ }
61
+
62
+ /**
63
+ * Callback function type alias (use for readability)
64
+ */
65
+ export type Callback = () => void;
66
+ export type Predicate<T> = (t: T) => boolean;
67
+
68
+ /**
69
+ * Create a predicate function that checks if a ReactNode is a react element from the given component.
70
+ *
71
+ * @param component React function component or the component name
72
+ * @return predicate returning true if value is instance of the component
73
+ */
74
+ export const isComponent = <C>(component: Comp<C, any> | string) => (instance: ReactNode): instance is ReactElement => {
75
+ const componentName = typeof component === 'string' ? component : component.displayName;
76
+
77
+ return (
78
+ !!get(instance, '$$typeof') &&
79
+ NAME_PROPERTIES.some((nameProperty: string): boolean => get(instance, nameProperty) === componentName)
80
+ );
81
+ };
82
+
83
+ /**
84
+ * Similar to `isComponent` but more precise as it's not based on the component `displayName` but on the component function reference.
85
+ */
86
+ export const isComponentType = (type: ReactElement['type']) => (node: ReactNode): node is ReactElement =>
87
+ React.isValidElement(node) && node.type === type;
88
+
89
+ /**
90
+ * JS falsy values.
91
+ * (excluding `NaN` as it can't be distinguished from `number`)
92
+ */
93
+ export type Falsy = false | undefined | null | 0 | '';
94
+
95
+ /**
96
+ * Require either `aria-label` or `arial-labelledby` prop.
97
+ * If none are set, the order will prioritize `aria-labelledby` over `aria-label` as it
98
+ * needs a visible element.
99
+ */
100
+ export type HasAriaLabelOrLabelledBy<T = string | undefined> = T extends string
101
+ ? {
102
+ /**
103
+ * The id of the element to use as title of the dialog. Can be within or out of the dialog.
104
+ * Although it is not recommended, aria-label can be used instead if no visible element is available.
105
+ */
106
+ 'aria-labelledby': T;
107
+ /** The label of the dialog. */
108
+ 'aria-label'?: undefined;
109
+ }
110
+ : {
111
+ 'aria-label': string;
112
+ 'aria-labelledby'?: undefined;
113
+ };
@@ -0,0 +1,7 @@
1
+ export const userHasReducedMotion = () => {
2
+ try {
3
+ return window.matchMedia('(prefers-reduced-motion: reduce)').matches;
4
+ } catch (e) {
5
+ return false;
6
+ }
7
+ };
@@ -0,0 +1,48 @@
1
+ import partition from 'lodash/partition';
2
+ import { partitionMulti } from './partitionMulti';
3
+ import { isInternetExplorer } from './isInternetExplorer';
4
+
5
+ describe(`partitionMulti`, () => {
6
+ it('should act like partition for single predicate', () => {
7
+ const data = [0, 1, 2, 3, 4, 5];
8
+ const isEven = (n: number): boolean => n % 2 === 0;
9
+
10
+ const expected = partition(data, isEven);
11
+ const actual = partitionMulti(data, [isEven]);
12
+
13
+ expect(actual).toEqual(expected);
14
+ });
15
+
16
+ it('should partition on multiple predicates', () => {
17
+ type T = string | number | boolean;
18
+ const data: T[] = ['a', 1, 'b', false, true];
19
+ const isString = (s: T): boolean => typeof s === 'string';
20
+ const isNumber = (s: T): boolean => typeof s === 'number';
21
+
22
+ const [strings, numbers, others] = partitionMulti(data, [isString, isNumber]);
23
+
24
+ expect(strings).toEqual(['a', 'b']);
25
+ expect(numbers).toEqual([1]);
26
+ expect(others).toEqual([false, true]);
27
+ });
28
+ });
29
+
30
+ describe(`isInternetExplorer`, () => {
31
+ it('should detect IE 10', () => {
32
+ const userAgentIE10 = `Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)`;
33
+ Object.defineProperty(window.navigator, 'userAgent', { value: userAgentIE10, configurable: true });
34
+ expect(isInternetExplorer()).toEqual(true);
35
+ });
36
+
37
+ it('should detect IE 11', () => {
38
+ const userAgentIE11 = `Mozilla/5.0 (Windows NT 10.0; Trident/7.0; rv:11.0) like Gecko`;
39
+ Object.defineProperty(window.navigator, 'userAgent', { value: userAgentIE11, configurable: true });
40
+ expect(isInternetExplorer()).toEqual(true);
41
+ });
42
+
43
+ it('should not detect IE', () => {
44
+ const userAgentFirefox = `Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:74.0) Gecko/20100101 Firefox/74.0`;
45
+ Object.defineProperty(window.navigator, 'userAgent', { value: userAgentFirefox, configurable: true });
46
+ expect(isInternetExplorer()).toEqual(false);
47
+ });
48
+ });
File without changes
File without changes
File without changes
@@ -0,0 +1,3 @@
1
+ module.exports = {
2
+ action: (name) => (event) => console.log(name, event),
3
+ };
@@ -0,0 +1,6 @@
1
+ module.exports = {
2
+ text: (name, defaultValue) => defaultValue,
3
+ number: (name, defaultValue) => defaultValue,
4
+ boolean: (name, defaultValue) => defaultValue,
5
+ select: (name, options, defaultValue) => defaultValue,
6
+ };
@@ -0,0 +1,8 @@
1
+ /* eslint-disable import/no-commonjs,import/unambiguous,import/no-nodejs-modules */
2
+ const path = require('path');
3
+
4
+ module.exports = {
5
+ process(src, filename) {
6
+ return `module.exports = ${JSON.stringify(path.basename(filename))};`;
7
+ },
8
+ };
@@ -0,0 +1 @@
1
+ module.exports = {};
@@ -0,0 +1,6 @@
1
+ const { configure } = require('enzyme');
2
+ const Adapter = require('enzyme-adapter-react-16');
3
+
4
+ configure({ adapter: new Adapter() });
5
+
6
+ import '@testing-library/jest-dom';
package/jest/index.js ADDED
@@ -0,0 +1,36 @@
1
+ /* eslint-disable */
2
+ const tsconfig = require('../../../tsconfig');
3
+ const CONFIGS = require('../../../configs');
4
+
5
+ const fromPairs = (pairs) => pairs.reduce((res, [key, value]) => ({ ...res, [key]: value }), {});
6
+
7
+ const moduleNameMapper = fromPairs(
8
+ Object.entries(tsconfig.compilerOptions.paths).map(([k, [v]]) => [
9
+ `^${k.replace(/\/\*/, '(.*)')}$`,
10
+ `${CONFIGS.path.ROOT_PATH}/packages/${v.replace(/\/\*/, '$1')}`,
11
+ ]),
12
+ );
13
+
14
+ module.exports = {
15
+ collectCoverageFrom: ['src/**/*.{ts,tsx}', '!src/**/*.stories.tsx'],
16
+ coverageDirectory: '<rootDir>jest/reports/coverage',
17
+ coverageReporters: ['json', 'lcov', 'html', 'text'],
18
+ moduleFileExtensions: ['js', 'jsx', 'ts', 'tsx'],
19
+ moduleNameMapper: {
20
+ '\\.scss$': '<rootDir>jest/__mocks__/emptyModuleMock.js',
21
+ ...moduleNameMapper,
22
+ },
23
+ reporters: ['default'],
24
+ rootDir: '../',
25
+ setupFilesAfterEnv: [
26
+ '<rootDir>jest/configure.js',
27
+ ],
28
+ snapshotSerializers: ['enzyme-to-json/serializer'],
29
+ testEnvironment: 'jsdom',
30
+ testMatch: ['<rootDir>src/**/?(*.)+(spec|test).[jt]s?(x)'],
31
+ transform: {
32
+ '^.+\\.(t|j)sx?$': '<rootDir>jest/transform.js',
33
+ // Mock file import returning their file path.
34
+ '\\.(jpg|jpeg|png|gif)$': '<rootDir>jest/__mocks__/emptyFileMockTransformer.js',
35
+ },
36
+ };
@@ -0,0 +1,6 @@
1
+ const CONFIGS = require('../../../configs');
2
+
3
+ module.exports = require('babel-jest').default.createTransformer({
4
+ plugins: CONFIGS.babel.plugins,
5
+ presets: [['@babel/preset-env', { targets: { node: 'current' } }], '@babel/react', '@babel/preset-typescript'],
6
+ });
package/package.json CHANGED
@@ -7,8 +7,8 @@
7
7
  },
8
8
  "dependencies": {
9
9
  "@juggle/resize-observer": "^3.2.0",
10
- "@lumx/core": "^3.0.7",
11
- "@lumx/icons": "^3.0.7",
10
+ "@lumx/core": "^3.1.0",
11
+ "@lumx/icons": "^3.1.0",
12
12
  "@popperjs/core": "^2.5.4",
13
13
  "body-scroll-lock": "^3.1.5",
14
14
  "classnames": "^2.2.6",
@@ -107,13 +107,11 @@
107
107
  "scripts": {
108
108
  "build": "rollup -c",
109
109
  "prepare": "install-peers || exit 0",
110
- "prepublishOnly": "yarn build",
111
110
  "test": "jest --config jest/index.js --coverage --notify --passWithNoTests --detectOpenHandles --runInBand",
112
111
  "storybook": "yarn start:storybook",
113
112
  "start:storybook": "cd storybook && ./start",
114
113
  "build:storybook": "cd storybook && ./build"
115
114
  },
116
115
  "sideEffects": false,
117
- "version": "3.0.7",
118
- "gitHead": "4fec43ef3290a9f250767d3bdecf60cfcf02ee75"
116
+ "version": "3.1.0"
119
117
  }
@@ -0,0 +1,98 @@
1
+ import path from 'path';
2
+ import commonjs from '@rollup/plugin-commonjs';
3
+ import resolve from '@rollup/plugin-node-resolve';
4
+ import analyze from 'rollup-plugin-analyzer';
5
+ import babel from 'rollup-plugin-babel';
6
+ import cleaner from 'rollup-plugin-cleaner';
7
+ import copy from 'rollup-plugin-copy';
8
+ import dts from 'rollup-plugin-dts';
9
+ import peerDepsExternal from 'rollup-plugin-peer-deps-external';
10
+ import tsPathsResolve from 'rollup-plugin-ts-paths-resolve';
11
+
12
+ import pkg from './package.json';
13
+ const CONFIGS = require('../../configs');
14
+
15
+ const ROOT_PATH = path.resolve(__dirname, '..', '..');
16
+ const DIST_PATH = path.resolve(__dirname, pkg.publishConfig.directory);
17
+ export const extensions = ['.js', '.jsx', '.ts', '.tsx'];
18
+
19
+ /**
20
+ * List of entry modules that will get compiled and exported to NPM.
21
+ * All other modules are considered as internal and won't be exposed.
22
+ */
23
+ const input = Object.fromEntries([
24
+ ['index', 'src/index.ts'], // => @lumx/react
25
+ ['utils/index', 'src/utils/index.ts'], // => @lumx/react/utils
26
+ ]);
27
+
28
+ // Bundle JS code
29
+ const bundleJS = {
30
+ input,
31
+ output: {
32
+ format: 'esm',
33
+ sourcemap: true,
34
+ hoistTransitiveImports: false,
35
+ dir: DIST_PATH,
36
+ // Unnamed chunk moved to `_internal` folder
37
+ chunkFileNames: '_internal/[name].js',
38
+ },
39
+ plugins: [
40
+ /** Clean dist dir */
41
+ cleaner({ targets: [DIST_PATH] }),
42
+ /** Externalize peer dependencies. */
43
+ peerDepsExternal(),
44
+ /** Analyze created bundle. */
45
+ analyze(),
46
+ /** Resolve tsconfig paths. */
47
+ tsPathsResolve(),
48
+ /** Resolve source files. */
49
+ resolve({ browser: true, extensions }),
50
+ /** Resolve commonjs dependencies. */
51
+ commonjs({ include: /node_modules/ }),
52
+ /** Transpile JS/TS. */
53
+ babel({
54
+ extensions,
55
+ exclude: /node_modules/,
56
+ plugins: CONFIGS.babel.plugins,
57
+ presets: [
58
+ ['@babel/preset-env', { targets: 'defaults' }],
59
+ '@babel/preset-react',
60
+ '@babel/preset-typescript',
61
+ ],
62
+ }),
63
+ /** Copy additional files to dist. */
64
+ copy({
65
+ targets: [
66
+ { src: path.join(ROOT_PATH, 'CONTRIBUTING.md'), dest: DIST_PATH },
67
+ { src: path.join(ROOT_PATH, 'LICENSE.md'), dest: DIST_PATH },
68
+ { src: path.join(__dirname, 'README.md'), dest: DIST_PATH },
69
+ { src: path.join(__dirname, 'package.json'), dest: DIST_PATH },
70
+ {
71
+ src: [path.join(__dirname, 'src'), '!**/*.snap', '!**/*.test.tsx', '!**/*.test.ts'],
72
+ dest: DIST_PATH,
73
+ },
74
+ ],
75
+ }),
76
+ ],
77
+ };
78
+
79
+ // Bundle TS types in D.TS files
80
+ const bundleType = {
81
+ input,
82
+ output: {
83
+ format: 'esm',
84
+ dir: DIST_PATH,
85
+ // Unnamed chunk moved to `_internal` folder
86
+ chunkFileNames: '_internal/[name].d.ts',
87
+ },
88
+ plugins: [
89
+ /** Externalize peer dependencies. */
90
+ peerDepsExternal(),
91
+ /** Resolve tsconfig paths. */
92
+ tsPathsResolve(),
93
+ /** Transform TS to D.TS file. */
94
+ dts({ respectExternal: true }),
95
+ ],
96
+ };
97
+
98
+ export default [bundleJS, bundleType];