@lumx/react 3.20.1-alpha.3 → 3.20.1-alpha.30

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 (698) hide show
  1. package/CONTRIBUTING.md +1 -5
  2. package/README.md +0 -2
  3. package/_internal/Button-4b67daa8.js +98 -0
  4. package/_internal/Button-4b67daa8.js.map +1 -0
  5. package/_internal/ButtonRoot-a70baf82.js +118 -0
  6. package/_internal/ButtonRoot-a70baf82.js.map +1 -0
  7. package/_internal/Chip-70af04b4.js +144 -0
  8. package/_internal/Chip-70af04b4.js.map +1 -0
  9. package/_internal/ClickAwayProvider-1204f237.js +95 -0
  10. package/_internal/ClickAwayProvider-1204f237.js.map +1 -0
  11. package/_internal/DisabledStateContext-ea04260d.js +29 -0
  12. package/_internal/DisabledStateContext-ea04260d.js.map +1 -0
  13. package/_internal/HeadingLevelProvider-ebdcb0c7.js +61 -0
  14. package/_internal/HeadingLevelProvider-ebdcb0c7.js.map +1 -0
  15. package/_internal/IconButton-8d61f5be.js +77 -0
  16. package/_internal/IconButton-8d61f5be.js.map +1 -0
  17. package/_internal/ImageCaption-db44ec9e.js +75 -0
  18. package/_internal/ImageCaption-db44ec9e.js.map +1 -0
  19. package/_internal/List-c75646f2.js +818 -0
  20. package/_internal/List-c75646f2.js.map +1 -0
  21. package/_internal/PopoverDialog-35b2d87d.js +657 -0
  22. package/_internal/PopoverDialog-35b2d87d.js.map +1 -0
  23. package/_internal/Portal-3f86608e.js +45 -0
  24. package/_internal/Portal-3f86608e.js.map +1 -0
  25. package/_internal/RawClickable-2c2b6a89.js +52 -0
  26. package/_internal/RawClickable-2c2b6a89.js.map +1 -0
  27. package/_internal/Slides-ce641b5f.js +679 -0
  28. package/_internal/Slides-ce641b5f.js.map +1 -0
  29. package/_internal/ThemeContext-3181f000.js +14 -0
  30. package/_internal/ThemeContext-3181f000.js.map +1 -0
  31. package/_internal/Thumbnail-02bd6869.js +314 -0
  32. package/_internal/Thumbnail-02bd6869.js.map +1 -0
  33. package/_internal/components/alert-dialog-a24330ed.js +166 -0
  34. package/_internal/components/alert-dialog-a24330ed.js.map +1 -0
  35. package/_internal/components/autocomplete-70749e51.js +262 -0
  36. package/_internal/components/autocomplete-70749e51.js.map +1 -0
  37. package/_internal/components/avatar-ed9f4869.js +84 -0
  38. package/_internal/components/avatar-ed9f4869.js.map +1 -0
  39. package/_internal/components/badge-ccf47147.js +82 -0
  40. package/_internal/components/badge-ccf47147.js.map +1 -0
  41. package/_internal/components/button-9f710830.js +48 -0
  42. package/_internal/components/button-9f710830.js.map +1 -0
  43. package/_internal/components/checkbox-8ab51ef9.js +142 -0
  44. package/_internal/components/checkbox-8ab51ef9.js.map +1 -0
  45. package/_internal/components/chip-19e40755.js +103 -0
  46. package/_internal/components/chip-19e40755.js.map +1 -0
  47. package/_internal/components/comment-block-bb6a0603.js +139 -0
  48. package/_internal/components/comment-block-bb6a0603.js.map +1 -0
  49. package/_internal/components/date-picker-e4209b01.js +2 -0
  50. package/_internal/components/date-picker-e4209b01.js.map +1 -0
  51. package/_internal/components/dialog-30336ccb.js +239 -0
  52. package/_internal/components/dialog-30336ccb.js.map +1 -0
  53. package/_internal/components/divider-0e93aa3d.js +51 -0
  54. package/_internal/components/divider-0e93aa3d.js.map +1 -0
  55. package/_internal/components/drag-handle-ba2e7e67.js +52 -0
  56. package/_internal/components/drag-handle-ba2e7e67.js.map +1 -0
  57. package/_internal/components/dropdown-d18122d7.js +148 -0
  58. package/_internal/components/dropdown-d18122d7.js.map +1 -0
  59. package/_internal/components/expansion-panel-0b263437.js +169 -0
  60. package/_internal/components/expansion-panel-0b263437.js.map +1 -0
  61. package/_internal/components/flag-8f9a498a.js +60 -0
  62. package/_internal/components/flag-8f9a498a.js.map +1 -0
  63. package/_internal/components/flex-box-15be92f6.js +57 -0
  64. package/_internal/components/flex-box-15be92f6.js.map +1 -0
  65. package/_internal/components/generic-block-5d843f1e.js +128 -0
  66. package/_internal/components/generic-block-5d843f1e.js.map +1 -0
  67. package/_internal/components/grid-8c08dc4b.js +105 -0
  68. package/_internal/components/grid-8c08dc4b.js.map +1 -0
  69. package/_internal/components/grid-column-85e305e7.js +59 -0
  70. package/_internal/components/grid-column-85e305e7.js.map +1 -0
  71. package/_internal/components/heading-7bfafd7d.js +54 -0
  72. package/_internal/components/heading-7bfafd7d.js.map +1 -0
  73. package/_internal/components/icon-ee15673b.js +103 -0
  74. package/_internal/components/icon-ee15673b.js.map +1 -0
  75. package/_internal/components/image-block-3479abda.js +111 -0
  76. package/_internal/components/image-block-3479abda.js.map +1 -0
  77. package/_internal/components/image-lightbox-1d7ca133.js +758 -0
  78. package/_internal/components/image-lightbox-1d7ca133.js.map +1 -0
  79. package/_internal/components/inline-list-5ba8bb0f.js +75 -0
  80. package/_internal/components/inline-list-5ba8bb0f.js.map +1 -0
  81. package/_internal/components/input-helper-2e4e49fd.js +72 -0
  82. package/_internal/components/input-helper-2e4e49fd.js.map +1 -0
  83. package/_internal/components/input-label-30d199c3.js +60 -0
  84. package/_internal/components/input-label-30d199c3.js.map +1 -0
  85. package/_internal/components/lightbox-c5f9afd0.js +156 -0
  86. package/_internal/components/lightbox-c5f9afd0.js.map +1 -0
  87. package/_internal/components/link-43ee103e.js +73 -0
  88. package/_internal/components/link-43ee103e.js.map +1 -0
  89. package/_internal/components/link-preview-db0ee2d6.js +118 -0
  90. package/_internal/components/link-preview-db0ee2d6.js.map +1 -0
  91. package/_internal/components/list-2f256244.js +72 -0
  92. package/_internal/components/list-2f256244.js.map +1 -0
  93. package/_internal/components/message-f7674e0e.js +101 -0
  94. package/_internal/components/message-f7674e0e.js.map +1 -0
  95. package/_internal/components/mosaic-3effd0cf.js +95 -0
  96. package/_internal/components/mosaic-3effd0cf.js.map +1 -0
  97. package/_internal/components/navigation-3a5dc270.js +227 -0
  98. package/_internal/components/navigation-3a5dc270.js.map +1 -0
  99. package/_internal/components/notification-098c5600.js +146 -0
  100. package/_internal/components/notification-098c5600.js.map +1 -0
  101. package/_internal/components/popover-dfcddda4.js +3 -0
  102. package/_internal/components/popover-dfcddda4.js.map +1 -0
  103. package/_internal/components/post-block-69797e4d.js +110 -0
  104. package/_internal/components/post-block-69797e4d.js.map +1 -0
  105. package/_internal/components/progress-44bb0301.js +183 -0
  106. package/_internal/components/progress-44bb0301.js.map +1 -0
  107. package/_internal/components/progress-tracker-e0981fcc.js +309 -0
  108. package/_internal/components/progress-tracker-e0981fcc.js.map +1 -0
  109. package/_internal/components/radio-button-929c7bee.js +150 -0
  110. package/_internal/components/radio-button-929c7bee.js.map +1 -0
  111. package/_internal/components/select-64bc72a0.js +458 -0
  112. package/_internal/components/select-64bc72a0.js.map +1 -0
  113. package/_internal/components/side-navigation-c610c689.js +166 -0
  114. package/_internal/components/side-navigation-c610c689.js.map +1 -0
  115. package/_internal/components/skeleton-1ea8c82a.js +167 -0
  116. package/_internal/components/skeleton-1ea8c82a.js.map +1 -0
  117. package/_internal/components/slider-78cfaa67.js +312 -0
  118. package/_internal/components/slider-78cfaa67.js.map +1 -0
  119. package/_internal/components/slideshow-d8a943a7.js +151 -0
  120. package/_internal/components/slideshow-d8a943a7.js.map +1 -0
  121. package/_internal/components/switch-25b65051.js +122 -0
  122. package/_internal/components/switch-25b65051.js.map +1 -0
  123. package/_internal/components/table-ec20c66c.js +296 -0
  124. package/_internal/components/table-ec20c66c.js.map +1 -0
  125. package/_internal/components/tabs-89c055bd.js +299 -0
  126. package/_internal/components/tabs-89c055bd.js.map +1 -0
  127. package/_internal/components/text-d04d0f1b.js +2 -0
  128. package/_internal/components/text-d04d0f1b.js.map +1 -0
  129. package/_internal/components/text-field-8f13957e.js +361 -0
  130. package/_internal/components/text-field-8f13957e.js.map +1 -0
  131. package/_internal/components/thumbnail-1255957f.js +42 -0
  132. package/_internal/components/thumbnail-1255957f.js.map +1 -0
  133. package/_internal/components/toolbar-e7c984e6.js +62 -0
  134. package/_internal/components/toolbar-e7c984e6.js.map +1 -0
  135. package/_internal/components/tooltip-dcb43bbe.js +328 -0
  136. package/_internal/components/tooltip-dcb43bbe.js.map +1 -0
  137. package/_internal/components/uploader-7ef4db39.js +154 -0
  138. package/_internal/components/uploader-7ef4db39.js.map +1 -0
  139. package/_internal/components/user-block-24d97650.js +145 -0
  140. package/_internal/components/user-block-24d97650.js.map +1 -0
  141. package/_internal/constants-43721918.js +2170 -0
  142. package/_internal/constants-43721918.js.map +1 -0
  143. package/_internal/constants-d0e3f49e.js +24 -0
  144. package/_internal/constants-d0e3f49e.js.map +1 -0
  145. package/_internal/context-9d1336a1.js +19 -0
  146. package/_internal/context-9d1336a1.js.map +1 -0
  147. package/_internal/forwardRef-8bce732e.js +9 -0
  148. package/_internal/forwardRef-8bce732e.js.map +1 -0
  149. package/_internal/getFocusableElements-230173a8.js +13 -0
  150. package/_internal/getFocusableElements-230173a8.js.map +1 -0
  151. package/_internal/index-25c9e8c2.js +118 -0
  152. package/_internal/index-25c9e8c2.js.map +1 -0
  153. package/_internal/index-25d2a45e.js +437 -0
  154. package/_internal/index-25d2a45e.js.map +1 -0
  155. package/_internal/isComponent-b9762ff1.js +18 -0
  156. package/_internal/isComponent-b9762ff1.js.map +1 -0
  157. package/_internal/isComponentType-e806b848.js +9 -0
  158. package/_internal/isComponentType-e806b848.js.map +1 -0
  159. package/_internal/mergeRefs-f0d7d6ea.js +30 -0
  160. package/_internal/mergeRefs-f0d7d6ea.js.map +1 -0
  161. package/_internal/state-db358714.js +130 -0
  162. package/_internal/state-db358714.js.map +1 -0
  163. package/_internal/useBooleanState-2a3d237c.js +12 -0
  164. package/_internal/useBooleanState-2a3d237c.js.map +1 -0
  165. package/_internal/useCallbackOnEscape-b956a85d.js +64 -0
  166. package/_internal/useCallbackOnEscape-b956a85d.js.map +1 -0
  167. package/_internal/useDisableBodyScroll-36bd7352.js +219 -0
  168. package/_internal/useDisableBodyScroll-36bd7352.js.map +1 -0
  169. package/_internal/useDisableStateProps-69e16b7c.js +36 -0
  170. package/_internal/useDisableStateProps-69e16b7c.js.map +1 -0
  171. package/_internal/useFocusTrap-2dbae79e.js +112 -0
  172. package/_internal/useFocusTrap-2dbae79e.js.map +1 -0
  173. package/_internal/useId-3a1facc0.js +18 -0
  174. package/_internal/useId-3a1facc0.js.map +1 -0
  175. package/_internal/useRovingTabIndex-7daf0f24.js +77 -0
  176. package/_internal/useRovingTabIndex-7daf0f24.js.map +1 -0
  177. package/_internal/useTransitionVisibility-321fdbfa.js +50 -0
  178. package/_internal/useTransitionVisibility-321fdbfa.js.map +1 -0
  179. package/_internal/wrapChildrenIconWithSpaces-50d705e6.js +20 -0
  180. package/_internal/wrapChildrenIconWithSpaces-50d705e6.js.map +1 -0
  181. package/index.d.ts +11 -368
  182. package/index.js +65 -14523
  183. package/index.js.map +1 -1
  184. package/package.json +8 -22
  185. package/utils/index.d.ts +1 -1
  186. package/utils/index.js +3 -1
  187. package/utils/index.js.map +1 -1
  188. package/_internal/Falsy.d.ts +0 -7
  189. package/_internal/index.js +0 -229
  190. package/_internal/index.js.map +0 -1
  191. package/src/components/alert-dialog/AlertDialog.stories.tsx +0 -127
  192. package/src/components/alert-dialog/AlertDialog.test.tsx +0 -34
  193. package/src/components/alert-dialog/AlertDialog.tsx +0 -189
  194. package/src/components/alert-dialog/index.ts +0 -1
  195. package/src/components/autocomplete/Autocomplete.stories.tsx +0 -75
  196. package/src/components/autocomplete/Autocomplete.test.tsx +0 -99
  197. package/src/components/autocomplete/Autocomplete.tsx +0 -294
  198. package/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -167
  199. package/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -61
  200. package/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
  201. package/src/components/autocomplete/__mockData__/index.ts +0 -39
  202. package/src/components/autocomplete/index.ts +0 -2
  203. package/src/components/avatar/Avatar.stories.tsx +0 -119
  204. package/src/components/avatar/Avatar.test.tsx +0 -32
  205. package/src/components/avatar/Avatar.tsx +0 -114
  206. package/src/components/avatar/index.ts +0 -1
  207. package/src/components/badge/Badge.stories.tsx +0 -69
  208. package/src/components/badge/Badge.test.tsx +0 -45
  209. package/src/components/badge/Badge.tsx +0 -58
  210. package/src/components/badge/BadgeWrapper.stories.tsx +0 -75
  211. package/src/components/badge/BadgeWrapper.test.tsx +0 -47
  212. package/src/components/badge/BadgeWrapper.tsx +0 -37
  213. package/src/components/badge/index.ts +0 -2
  214. package/src/components/button/Button.stories.tsx +0 -355
  215. package/src/components/button/Button.test.tsx +0 -125
  216. package/src/components/button/Button.tsx +0 -101
  217. package/src/components/button/ButtonGroup.stories.tsx +0 -52
  218. package/src/components/button/ButtonGroup.test.tsx +0 -41
  219. package/src/components/button/ButtonGroup.tsx +0 -50
  220. package/src/components/button/ButtonRoot.tsx +0 -163
  221. package/src/components/button/IconButton.stories.tsx +0 -52
  222. package/src/components/button/IconButton.test.tsx +0 -66
  223. package/src/components/button/IconButton.tsx +0 -91
  224. package/src/components/button/index.ts +0 -4
  225. package/src/components/checkbox/Checkbox.stories.tsx +0 -64
  226. package/src/components/checkbox/Checkbox.test.tsx +0 -154
  227. package/src/components/checkbox/Checkbox.tsx +0 -164
  228. package/src/components/checkbox/index.ts +0 -1
  229. package/src/components/chip/Chip.stories.tsx +0 -164
  230. package/src/components/chip/Chip.test.tsx +0 -243
  231. package/src/components/chip/Chip.tsx +0 -168
  232. package/src/components/chip/ChipGroup.stories.tsx +0 -47
  233. package/src/components/chip/ChipGroup.test.tsx +0 -37
  234. package/src/components/chip/ChipGroup.tsx +0 -60
  235. package/src/components/chip/index.ts +0 -2
  236. package/src/components/comment-block/CommentBlock.stories.tsx +0 -91
  237. package/src/components/comment-block/CommentBlock.test.tsx +0 -28
  238. package/src/components/comment-block/CommentBlock.tsx +0 -172
  239. package/src/components/comment-block/index.ts +0 -1
  240. package/src/components/date-picker/DatePicker.stories.tsx +0 -118
  241. package/src/components/date-picker/DatePicker.test.tsx +0 -34
  242. package/src/components/date-picker/DatePicker.tsx +0 -52
  243. package/src/components/date-picker/DatePickerControlled.test.tsx +0 -91
  244. package/src/components/date-picker/DatePickerControlled.tsx +0 -259
  245. package/src/components/date-picker/DatePickerField.stories.tsx +0 -100
  246. package/src/components/date-picker/DatePickerField.test.tsx +0 -70
  247. package/src/components/date-picker/DatePickerField.tsx +0 -135
  248. package/src/components/date-picker/constants.ts +0 -11
  249. package/src/components/date-picker/index.ts +0 -4
  250. package/src/components/date-picker/types.ts +0 -28
  251. package/src/components/dialog/Dialog.stories.tsx +0 -318
  252. package/src/components/dialog/Dialog.test.tsx +0 -97
  253. package/src/components/dialog/Dialog.tsx +0 -288
  254. package/src/components/dialog/index.ts +0 -1
  255. package/src/components/divider/Divider.test.tsx +0 -51
  256. package/src/components/divider/Divider.tsx +0 -50
  257. package/src/components/divider/index.ts +0 -1
  258. package/src/components/drag-handle/DragHandle.test.tsx +0 -36
  259. package/src/components/drag-handle/DragHandle.tsx +0 -51
  260. package/src/components/drag-handle/index.ts +0 -1
  261. package/src/components/dropdown/Dropdown.stories.tsx +0 -31
  262. package/src/components/dropdown/Dropdown.test.tsx +0 -66
  263. package/src/components/dropdown/Dropdown.tsx +0 -186
  264. package/src/components/dropdown/index.ts +0 -1
  265. package/src/components/expansion-panel/ExpansionPanel.stories.tsx +0 -91
  266. package/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -185
  267. package/src/components/expansion-panel/ExpansionPanel.tsx +0 -195
  268. package/src/components/expansion-panel/index.ts +0 -1
  269. package/src/components/flag/Flag.stories.tsx +0 -48
  270. package/src/components/flag/Flag.test.tsx +0 -62
  271. package/src/components/flag/Flag.tsx +0 -52
  272. package/src/components/flag/index.ts +0 -1
  273. package/src/components/flex-box/FlexBox.stories.tsx +0 -156
  274. package/src/components/flex-box/FlexBox.test.tsx +0 -24
  275. package/src/components/flex-box/FlexBox.tsx +0 -100
  276. package/src/components/flex-box/index.ts +0 -1
  277. package/src/components/generic-block/GenericBlock.stories.jsx +0 -128
  278. package/src/components/generic-block/GenericBlock.test.tsx +0 -156
  279. package/src/components/generic-block/GenericBlock.tsx +0 -225
  280. package/src/components/generic-block/constants.ts +0 -9
  281. package/src/components/generic-block/index.ts +0 -2
  282. package/src/components/grid/Grid.tsx +0 -83
  283. package/src/components/grid/GridItem.tsx +0 -55
  284. package/src/components/grid/index.ts +0 -2
  285. package/src/components/grid-column/GridColumn.stories.tsx +0 -45
  286. package/src/components/grid-column/GridColumn.test.jsx +0 -56
  287. package/src/components/grid-column/GridColumn.tsx +0 -83
  288. package/src/components/grid-column/index.ts +0 -1
  289. package/src/components/heading/Heading.stories.tsx +0 -69
  290. package/src/components/heading/Heading.test.tsx +0 -82
  291. package/src/components/heading/Heading.tsx +0 -65
  292. package/src/components/heading/HeadingLevelProvider.tsx +0 -30
  293. package/src/components/heading/constants.ts +0 -16
  294. package/src/components/heading/context.tsx +0 -13
  295. package/src/components/heading/index.ts +0 -3
  296. package/src/components/heading/useHeadingLevel.tsx +0 -8
  297. package/src/components/icon/Icon.stories.tsx +0 -73
  298. package/src/components/icon/Icon.test.tsx +0 -125
  299. package/src/components/icon/Icon.tsx +0 -22
  300. package/src/components/icon/index.ts +0 -1
  301. package/src/components/image-block/ImageBlock.stories.tsx +0 -117
  302. package/src/components/image-block/ImageBlock.test.tsx +0 -58
  303. package/src/components/image-block/ImageBlock.tsx +0 -142
  304. package/src/components/image-block/ImageCaption.tsx +0 -115
  305. package/src/components/image-block/index.ts +0 -1
  306. package/src/components/image-lightbox/ImageLightbox.stories.tsx +0 -160
  307. package/src/components/image-lightbox/ImageLightbox.test.tsx +0 -254
  308. package/src/components/image-lightbox/ImageLightbox.tsx +0 -90
  309. package/src/components/image-lightbox/constants.ts +0 -11
  310. package/src/components/image-lightbox/index.ts +0 -2
  311. package/src/components/image-lightbox/internal/ImageSlide.tsx +0 -107
  312. package/src/components/image-lightbox/internal/ImageSlideshow.tsx +0 -164
  313. package/src/components/image-lightbox/internal/useAnimateScroll.ts +0 -55
  314. package/src/components/image-lightbox/internal/usePointerZoom.ts +0 -148
  315. package/src/components/image-lightbox/types.ts +0 -48
  316. package/src/components/image-lightbox/useImageLightbox.tsx +0 -141
  317. package/src/components/inline-list/InlineList.stories.tsx +0 -77
  318. package/src/components/inline-list/InlineList.test.tsx +0 -52
  319. package/src/components/inline-list/InlineList.tsx +0 -96
  320. package/src/components/inline-list/index.ts +0 -1
  321. package/src/components/input-helper/InputHelper.stories.tsx +0 -35
  322. package/src/components/input-helper/InputHelper.test.tsx +0 -55
  323. package/src/components/input-helper/InputHelper.tsx +0 -65
  324. package/src/components/input-helper/constants.ts +0 -11
  325. package/src/components/input-helper/index.ts +0 -1
  326. package/src/components/input-label/InputLabel.stories.tsx +0 -45
  327. package/src/components/input-label/InputLabel.test.tsx +0 -59
  328. package/src/components/input-label/InputLabel.tsx +0 -69
  329. package/src/components/input-label/index.ts +0 -1
  330. package/src/components/lightbox/Lightbox.stories.tsx +0 -101
  331. package/src/components/lightbox/Lightbox.test.tsx +0 -53
  332. package/src/components/lightbox/Lightbox.tsx +0 -180
  333. package/src/components/lightbox/index.ts +0 -1
  334. package/src/components/link/Link.stories.tsx +0 -195
  335. package/src/components/link/Link.test.tsx +0 -127
  336. package/src/components/link/Link.tsx +0 -106
  337. package/src/components/link/index.ts +0 -1
  338. package/src/components/link-preview/LinkPreview.stories.tsx +0 -61
  339. package/src/components/link-preview/LinkPreview.test.tsx +0 -105
  340. package/src/components/link-preview/LinkPreview.tsx +0 -158
  341. package/src/components/link-preview/index.ts +0 -1
  342. package/src/components/list/List.stories.tsx +0 -116
  343. package/src/components/list/List.test.tsx +0 -18
  344. package/src/components/list/List.tsx +0 -104
  345. package/src/components/list/ListDivider.stories.tsx +0 -12
  346. package/src/components/list/ListDivider.test.tsx +0 -22
  347. package/src/components/list/ListDivider.tsx +0 -35
  348. package/src/components/list/ListItem.stories.tsx +0 -66
  349. package/src/components/list/ListItem.test.tsx +0 -93
  350. package/src/components/list/ListItem.tsx +0 -157
  351. package/src/components/list/ListSubheader.stories.tsx +0 -11
  352. package/src/components/list/ListSubheader.test.tsx +0 -21
  353. package/src/components/list/ListSubheader.tsx +0 -44
  354. package/src/components/list/index.ts +0 -4
  355. package/src/components/list/useInteractiveList.tsx +0 -202
  356. package/src/components/message/Message.stories.tsx +0 -72
  357. package/src/components/message/Message.test.tsx +0 -76
  358. package/src/components/message/Message.tsx +0 -100
  359. package/src/components/message/index.ts +0 -1
  360. package/src/components/mosaic/Mosaic.stories.tsx +0 -89
  361. package/src/components/mosaic/Mosaic.test.tsx +0 -77
  362. package/src/components/mosaic/Mosaic.tsx +0 -98
  363. package/src/components/mosaic/index.ts +0 -1
  364. package/src/components/navigation/Navigation.stories.tsx +0 -234
  365. package/src/components/navigation/Navigation.test.tsx +0 -65
  366. package/src/components/navigation/Navigation.tsx +0 -79
  367. package/src/components/navigation/NavigationItem.test.tsx +0 -35
  368. package/src/components/navigation/NavigationItem.tsx +0 -82
  369. package/src/components/navigation/NavigationSection.test.tsx +0 -137
  370. package/src/components/navigation/NavigationSection.tsx +0 -108
  371. package/src/components/navigation/context.tsx +0 -7
  372. package/src/components/navigation/index.ts +0 -1
  373. package/src/components/notification/Notification.test.tsx +0 -94
  374. package/src/components/notification/Notification.tsx +0 -138
  375. package/src/components/notification/Notifications.stories.tsx +0 -92
  376. package/src/components/notification/constants.ts +0 -28
  377. package/src/components/notification/index.ts +0 -1
  378. package/src/components/popover/Popover.stories.tsx +0 -264
  379. package/src/components/popover/Popover.test.tsx +0 -62
  380. package/src/components/popover/Popover.tsx +0 -201
  381. package/src/components/popover/constants.ts +0 -62
  382. package/src/components/popover/index.ts +0 -3
  383. package/src/components/popover/usePopoverStyle.tsx +0 -184
  384. package/src/components/popover/useRestoreFocusOnClose.tsx +0 -47
  385. package/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -64
  386. package/src/components/popover-dialog/PopoverDialog.test.tsx +0 -139
  387. package/src/components/popover-dialog/PopoverDialog.tsx +0 -74
  388. package/src/components/popover-dialog/index.tsx +0 -1
  389. package/src/components/post-block/PostBlock.test.tsx +0 -27
  390. package/src/components/post-block/PostBlock.tsx +0 -122
  391. package/src/components/post-block/index.ts +0 -1
  392. package/src/components/progress/Progress.tsx +0 -68
  393. package/src/components/progress/ProgressCircular.stories.tsx +0 -43
  394. package/src/components/progress/ProgressCircular.test.tsx +0 -46
  395. package/src/components/progress/ProgressCircular.tsx +0 -82
  396. package/src/components/progress/ProgressLinear.stories.tsx +0 -12
  397. package/src/components/progress/ProgressLinear.test.tsx +0 -30
  398. package/src/components/progress/ProgressLinear.tsx +0 -50
  399. package/src/components/progress/index.ts +0 -3
  400. package/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
  401. package/src/components/progress-tracker/ProgressTracker.test.tsx +0 -42
  402. package/src/components/progress-tracker/ProgressTracker.tsx +0 -87
  403. package/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -65
  404. package/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -67
  405. package/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -36
  406. package/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
  407. package/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -34
  408. package/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -67
  409. package/src/components/progress-tracker/index.ts +0 -4
  410. package/src/components/radio-button/RadioButton.stories.tsx +0 -71
  411. package/src/components/radio-button/RadioButton.test.tsx +0 -143
  412. package/src/components/radio-button/RadioButton.tsx +0 -143
  413. package/src/components/radio-button/RadioGroup.stories.tsx +0 -39
  414. package/src/components/radio-button/RadioGroup.test.tsx +0 -29
  415. package/src/components/radio-button/RadioGroup.tsx +0 -44
  416. package/src/components/radio-button/index.ts +0 -2
  417. package/src/components/select/Select.stories.tsx +0 -385
  418. package/src/components/select/Select.test.tsx +0 -199
  419. package/src/components/select/Select.tsx +0 -199
  420. package/src/components/select/SelectMultiple.stories.tsx +0 -315
  421. package/src/components/select/SelectMultiple.test.tsx +0 -213
  422. package/src/components/select/SelectMultiple.tsx +0 -206
  423. package/src/components/select/WithSelectContext.tsx +0 -147
  424. package/src/components/select/constants.ts +0 -55
  425. package/src/components/select/index.ts +0 -2
  426. package/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
  427. package/src/components/side-navigation/SideNavigation.test.tsx +0 -37
  428. package/src/components/side-navigation/SideNavigation.tsx +0 -52
  429. package/src/components/side-navigation/SideNavigationItem.stories.tsx +0 -133
  430. package/src/components/side-navigation/SideNavigationItem.test.tsx +0 -136
  431. package/src/components/side-navigation/SideNavigationItem.tsx +0 -165
  432. package/src/components/side-navigation/index.ts +0 -2
  433. package/src/components/skeleton/SkeletonCircle.stories.tsx +0 -41
  434. package/src/components/skeleton/SkeletonCircle.test.tsx +0 -27
  435. package/src/components/skeleton/SkeletonCircle.tsx +0 -52
  436. package/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -82
  437. package/src/components/skeleton/SkeletonRectangle.test.tsx +0 -27
  438. package/src/components/skeleton/SkeletonRectangle.tsx +0 -88
  439. package/src/components/skeleton/SkeletonTypography.stories.tsx +0 -19
  440. package/src/components/skeleton/SkeletonTypography.test.tsx +0 -27
  441. package/src/components/skeleton/SkeletonTypography.tsx +0 -59
  442. package/src/components/skeleton/index.ts +0 -3
  443. package/src/components/slider/Slider.stories.tsx +0 -45
  444. package/src/components/slider/Slider.test.tsx +0 -29
  445. package/src/components/slider/Slider.tsx +0 -299
  446. package/src/components/slider/index.ts +0 -2
  447. package/src/components/slideshow/Slides.tsx +0 -130
  448. package/src/components/slideshow/Slideshow.stories.tsx +0 -179
  449. package/src/components/slideshow/Slideshow.test.tsx +0 -35
  450. package/src/components/slideshow/Slideshow.tsx +0 -173
  451. package/src/components/slideshow/SlideshowControls.stories.tsx +0 -100
  452. package/src/components/slideshow/SlideshowControls.tsx +0 -243
  453. package/src/components/slideshow/SlideshowItem.tsx +0 -44
  454. package/src/components/slideshow/SlideshowItemGroup.tsx +0 -60
  455. package/src/components/slideshow/constants.ts +0 -24
  456. package/src/components/slideshow/index.ts +0 -4
  457. package/src/components/slideshow/useKeyNavigate.ts +0 -28
  458. package/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
  459. package/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
  460. package/src/components/slideshow/useSwipeNavigate.ts +0 -18
  461. package/src/components/switch/Switch.stories.tsx +0 -49
  462. package/src/components/switch/Switch.test.tsx +0 -144
  463. package/src/components/switch/Switch.tsx +0 -145
  464. package/src/components/switch/index.ts +0 -1
  465. package/src/components/table/Table.test.tsx +0 -29
  466. package/src/components/table/Table.tsx +0 -59
  467. package/src/components/table/TableBody.test.tsx +0 -30
  468. package/src/components/table/TableBody.tsx +0 -42
  469. package/src/components/table/TableCell.test.tsx +0 -72
  470. package/src/components/table/TableCell.tsx +0 -130
  471. package/src/components/table/TableHeader.test.tsx +0 -30
  472. package/src/components/table/TableHeader.tsx +0 -48
  473. package/src/components/table/TableRow.test.tsx +0 -40
  474. package/src/components/table/TableRow.tsx +0 -71
  475. package/src/components/table/index.ts +0 -5
  476. package/src/components/tabs/Tab.test.tsx +0 -50
  477. package/src/components/tabs/Tab.tsx +0 -133
  478. package/src/components/tabs/TabList.test.tsx +0 -49
  479. package/src/components/tabs/TabList.tsx +0 -94
  480. package/src/components/tabs/TabPanel.test.tsx +0 -37
  481. package/src/components/tabs/TabPanel.tsx +0 -67
  482. package/src/components/tabs/TabProvider.test.tsx +0 -161
  483. package/src/components/tabs/TabProvider.tsx +0 -67
  484. package/src/components/tabs/Tabs.stories.tsx +0 -170
  485. package/src/components/tabs/index.ts +0 -4
  486. package/src/components/tabs/state.ts +0 -114
  487. package/src/components/tabs/test-utils.ts +0 -39
  488. package/src/components/text/Text.stories.tsx +0 -177
  489. package/src/components/text/Text.test.tsx +0 -92
  490. package/src/components/text/Text.tsx +0 -139
  491. package/src/components/text/index.ts +0 -1
  492. package/src/components/text-field/TextField.stories.tsx +0 -180
  493. package/src/components/text-field/TextField.test.tsx +0 -298
  494. package/src/components/text-field/TextField.tsx +0 -493
  495. package/src/components/text-field/index.ts +0 -1
  496. package/src/components/thumbnail/Thumbnail.stories.tsx +0 -448
  497. package/src/components/thumbnail/Thumbnail.test.tsx +0 -88
  498. package/src/components/thumbnail/Thumbnail.tsx +0 -248
  499. package/src/components/thumbnail/index.ts +0 -3
  500. package/src/components/thumbnail/types.ts +0 -48
  501. package/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
  502. package/src/components/thumbnail/useFocusPointStyle.tsx +0 -107
  503. package/src/components/thumbnail/useImageLoad.ts +0 -40
  504. package/src/components/toolbar/Toolbar.tsx +0 -68
  505. package/src/components/toolbar/index.ts +0 -1
  506. package/src/components/tooltip/Tooltip.stories.tsx +0 -118
  507. package/src/components/tooltip/Tooltip.test.tsx +0 -417
  508. package/src/components/tooltip/Tooltip.tsx +0 -165
  509. package/src/components/tooltip/constants.ts +0 -8
  510. package/src/components/tooltip/context.tsx +0 -17
  511. package/src/components/tooltip/index.ts +0 -1
  512. package/src/components/tooltip/useInjectTooltipRef.tsx +0 -55
  513. package/src/components/tooltip/useTooltipOpen.tsx +0 -143
  514. package/src/components/uploader/Uploader.stories.tsx +0 -109
  515. package/src/components/uploader/Uploader.test.tsx +0 -146
  516. package/src/components/uploader/Uploader.tsx +0 -177
  517. package/src/components/uploader/index.ts +0 -1
  518. package/src/components/user-block/UserBlock.stories.tsx +0 -133
  519. package/src/components/user-block/UserBlock.test.tsx +0 -106
  520. package/src/components/user-block/UserBlock.tsx +0 -193
  521. package/src/components/user-block/index.ts +0 -1
  522. package/src/constants.ts +0 -27
  523. package/src/hooks/useBooleanState.tsx +0 -13
  524. package/src/hooks/useCallbackOnEscape.ts +0 -34
  525. package/src/hooks/useChipGroupNavigation.tsx +0 -75
  526. package/src/hooks/useClickAway.tsx +0 -48
  527. package/src/hooks/useDisableBodyScroll.ts +0 -28
  528. package/src/hooks/useEventCallback.tsx +0 -17
  529. package/src/hooks/useFocus.tsx +0 -21
  530. package/src/hooks/useFocusTrap.ts +0 -93
  531. package/src/hooks/useFocusWithin.ts +0 -33
  532. package/src/hooks/useId.test.tsx +0 -22
  533. package/src/hooks/useId.ts +0 -15
  534. package/src/hooks/useImageSize.ts +0 -17
  535. package/src/hooks/useInfiniteScroll.tsx +0 -60
  536. package/src/hooks/useIntersectionObserver.tsx +0 -43
  537. package/src/hooks/useInterval.tsx +0 -31
  538. package/src/hooks/useKeyboardListNavigation.tsx +0 -204
  539. package/src/hooks/useListenFocus.tsx +0 -26
  540. package/src/hooks/useOverflowTooltipLabel.tsx +0 -32
  541. package/src/hooks/usePopper.ts +0 -12
  542. package/src/hooks/usePreviousValue.ts +0 -12
  543. package/src/hooks/useRovingTabIndex.tsx +0 -90
  544. package/src/hooks/useSizeOnWindowResize.ts +0 -30
  545. package/src/hooks/useSlideshowControls.ts +0 -246
  546. package/src/hooks/useStopPropagation.ts +0 -21
  547. package/src/hooks/useTransitionVisibility.ts +0 -48
  548. package/src/index.ts +0 -63
  549. package/src/stories/controls/color.ts +0 -7
  550. package/src/stories/controls/element.ts +0 -6
  551. package/src/stories/controls/focusPoint.ts +0 -1
  552. package/src/stories/controls/icons.ts +0 -126
  553. package/src/stories/controls/image.ts +0 -84
  554. package/src/stories/controls/selectArgType.ts +0 -8
  555. package/src/stories/controls/theme.ts +0 -3
  556. package/src/stories/controls/typography.ts +0 -5
  557. package/src/stories/controls/withUndefined.ts +0 -1
  558. package/src/stories/decorators/withChromaticForceScreenSize.tsx +0 -7
  559. package/src/stories/decorators/withCombinations.tsx +0 -132
  560. package/src/stories/decorators/withNestedProps.tsx +0 -22
  561. package/src/stories/decorators/withResizableBox.tsx +0 -21
  562. package/src/stories/decorators/withThemedBackground.tsx +0 -16
  563. package/src/stories/decorators/withValueOnChange.tsx +0 -18
  564. package/src/stories/decorators/withWrapper.tsx +0 -19
  565. package/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
  566. package/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
  567. package/src/stories/generated/Badge/Demos.stories.tsx +0 -9
  568. package/src/stories/generated/Button/Demos.stories.tsx +0 -11
  569. package/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
  570. package/src/stories/generated/Chip/Demos.stories.tsx +0 -11
  571. package/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
  572. package/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
  573. package/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
  574. package/src/stories/generated/Divider/Demos.stories.tsx +0 -6
  575. package/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
  576. package/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
  577. package/src/stories/generated/Flag/Demos.stories.tsx +0 -6
  578. package/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
  579. package/src/stories/generated/Heading/Demos.stories.tsx +0 -6
  580. package/src/stories/generated/Icon/Demos.stories.tsx +0 -8
  581. package/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
  582. package/src/stories/generated/ImageLightbox/Demos.stories.tsx +0 -6
  583. package/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
  584. package/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
  585. package/src/stories/generated/List/Demos.stories.tsx +0 -11
  586. package/src/stories/generated/Message/Demos.stories.tsx +0 -11
  587. package/src/stories/generated/Mosaic/Demos.stories.tsx +0 -10
  588. package/src/stories/generated/Notification/Demos.stories.tsx +0 -6
  589. package/src/stories/generated/Popover/Demos.stories.tsx +0 -11
  590. package/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
  591. package/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
  592. package/src/stories/generated/Progress/Demos.stories.tsx +0 -7
  593. package/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
  594. package/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
  595. package/src/stories/generated/Select/Demos.stories.tsx +0 -14
  596. package/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
  597. package/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
  598. package/src/stories/generated/Slider/Demos.stories.tsx +0 -9
  599. package/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
  600. package/src/stories/generated/Switch/Demos.stories.tsx +0 -6
  601. package/src/stories/generated/Table/Demos.stories.tsx +0 -7
  602. package/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
  603. package/src/stories/generated/TextField/Demos.stories.tsx +0 -20
  604. package/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
  605. package/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
  606. package/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
  607. package/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
  608. package/src/stories/generated/UserBlock/Demos.stories.tsx +0 -11
  609. package/src/stories/utils/CustomLink.tsx +0 -12
  610. package/src/stories/utils/concatPath.tsx +0 -17
  611. package/src/stories/utils/disableArgTypes.ts +0 -3
  612. package/src/stories/utils/initDemoShadowDOMPortal.ts +0 -10
  613. package/src/stories/utils/lorem.ts +0 -59
  614. package/src/stories/utils/theming.tsx +0 -166
  615. package/src/stories/utils/toFlattenProps.ts +0 -28
  616. package/src/stories/utils/withCategory.ts +0 -12
  617. package/src/testing/utils/ThemeSentinel.tsx +0 -10
  618. package/src/testing/utils/commonTestsSuiteRTL.tsx +0 -193
  619. package/src/testing/utils/index.ts +0 -1
  620. package/src/testing/utils/queries.ts +0 -19
  621. package/src/untypped-modules.d.ts +0 -9
  622. package/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -70
  623. package/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -69
  624. package/src/utils/ClickAwayProvider/index.ts +0 -1
  625. package/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
  626. package/src/utils/MaterialThemeSwitcher/index.ts +0 -1
  627. package/src/utils/Portal/Portal.test.tsx +0 -31
  628. package/src/utils/Portal/Portal.tsx +0 -33
  629. package/src/utils/Portal/PortalProvider.stories.jsx +0 -22
  630. package/src/utils/Portal/PortalProvider.test.tsx +0 -72
  631. package/src/utils/Portal/PortalProvider.tsx +0 -24
  632. package/src/utils/Portal/index.tsx +0 -2
  633. package/src/utils/browser/DOM/findImage.tsx +0 -3
  634. package/src/utils/browser/DOM/startViewTransition.ts +0 -68
  635. package/src/utils/browser/focus/constants.ts +0 -7
  636. package/src/utils/browser/focus/getFirstAndLastFocusable.test.ts +0 -134
  637. package/src/utils/browser/focus/getFirstAndLastFocusable.ts +0 -21
  638. package/src/utils/browser/focus/getFocusableElements.test.ts +0 -151
  639. package/src/utils/browser/focus/getFocusableElements.ts +0 -7
  640. package/src/utils/browser/isFocusVisible.ts +0 -9
  641. package/src/utils/browser/isHoverNotSupported.test.js +0 -24
  642. package/src/utils/browser/isHoverNotSupported.ts +0 -2
  643. package/src/utils/browser/isReducedMotion.ts +0 -6
  644. package/src/utils/date/addMonthResetDay.test.ts +0 -13
  645. package/src/utils/date/addMonthResetDay.ts +0 -9
  646. package/src/utils/date/formatDayNumber.test.ts +0 -12
  647. package/src/utils/date/formatDayNumber.ts +0 -5
  648. package/src/utils/date/getFirstDayOfWeek.test.ts +0 -20
  649. package/src/utils/date/getFirstDayOfWeek.ts +0 -59
  650. package/src/utils/date/getMonthCalendar.test.ts +0 -127
  651. package/src/utils/date/getMonthCalendar.ts +0 -69
  652. package/src/utils/date/getWeekDays.test.ts +0 -48
  653. package/src/utils/date/getWeekDays.ts +0 -34
  654. package/src/utils/date/getYearDisplayName.test.ts +0 -20
  655. package/src/utils/date/getYearDisplayName.ts +0 -12
  656. package/src/utils/date/isDateValid.test.ts +0 -15
  657. package/src/utils/date/isDateValid.ts +0 -4
  658. package/src/utils/date/isSameDay.test.ts +0 -37
  659. package/src/utils/date/isSameDay.ts +0 -11
  660. package/src/utils/disabled/DisabledStateContext.tsx +0 -29
  661. package/src/utils/disabled/DisabledStateProvider.stories.tsx +0 -92
  662. package/src/utils/disabled/index.ts +0 -2
  663. package/src/utils/disabled/useDisableStateProps.test.tsx +0 -74
  664. package/src/utils/disabled/useDisableStateProps.tsx +0 -37
  665. package/src/utils/function/makeListenerTowerContext.ts +0 -32
  666. package/src/utils/index.ts +0 -7
  667. package/src/utils/locale/getCurrentLocale.ts +0 -4
  668. package/src/utils/locale/parseLocale.test.ts +0 -17
  669. package/src/utils/locale/parseLocale.ts +0 -23
  670. package/src/utils/locale/types.ts +0 -8
  671. package/src/utils/number/clamp.ts +0 -17
  672. package/src/utils/object/isEqual.test.ts +0 -25
  673. package/src/utils/object/isEqual.ts +0 -11
  674. package/src/utils/partitionMulti.test.ts +0 -27
  675. package/src/utils/partitionMulti.ts +0 -29
  676. package/src/utils/react/OnBeforeUnmount.tsx +0 -20
  677. package/src/utils/react/RawClickable.test.tsx +0 -153
  678. package/src/utils/react/RawClickable.tsx +0 -65
  679. package/src/utils/react/flattenChildren.ts +0 -32
  680. package/src/utils/react/forwardRef.ts +0 -11
  681. package/src/utils/react/forwardRefPolymorphic.ts +0 -9
  682. package/src/utils/react/mergeRefs.ts +0 -33
  683. package/src/utils/react/renderLink.tsx +0 -17
  684. package/src/utils/react/skipRender.tsx +0 -18
  685. package/src/utils/react/unref.ts +0 -7
  686. package/src/utils/react/wrapChildrenIconWithSpaces.test.tsx +0 -37
  687. package/src/utils/react/wrapChildrenIconWithSpaces.tsx +0 -22
  688. package/src/utils/theme/ThemeContext.ts +0 -16
  689. package/src/utils/theme/invertTheme.ts +0 -4
  690. package/src/utils/type/Comp.ts +0 -14
  691. package/src/utils/type/ComponentRef.ts +0 -16
  692. package/src/utils/type/HasAriaDisabled.ts +0 -6
  693. package/src/utils/type/HasPolymorphicAs.ts +0 -6
  694. package/src/utils/type/HasRequiredLinkHref.ts +0 -1
  695. package/src/utils/type/MaybeElementOrRef.ts +0 -6
  696. package/src/utils/type/index.ts +0 -9
  697. package/src/utils/type/isComponent.ts +0 -33
  698. package/src/utils/type/isComponentType.ts +0 -9
@@ -1,37 +0,0 @@
1
- import { useDisabledStateContext } from './DisabledStateContext';
2
-
3
- type GenericProps = {
4
- disabled?: boolean;
5
- isDisabled?: boolean;
6
- 'aria-disabled'?: boolean | 'true' | 'false';
7
- onClick?: any;
8
- onChange?: any;
9
- };
10
-
11
- interface Output<TProps extends GenericProps> {
12
- /** Is disabled or aria-disabled */
13
- isAnyDisabled?: boolean;
14
- disabledStateProps: { disabled?: boolean; 'aria-disabled'?: boolean };
15
- otherProps: TProps & { disabled: never; 'aria-disabled': never; isDisabled: never };
16
- }
17
-
18
- /**
19
- * Resolve disabled state from props.
20
- * (handles `disabled`, `isDisabled` and `aria-disabled`)
21
- *
22
- * @params component props
23
- */
24
- export function useDisableStateProps<TProps extends GenericProps>(props: TProps): Output<TProps> {
25
- const { disabled, isDisabled = disabled, 'aria-disabled': ariaDisabled, onClick, onChange, ...otherProps } = props;
26
- const disabledStateContext = useDisabledStateContext();
27
- const disabledStateProps = {
28
- disabled: disabledStateContext?.state === 'disabled' || isDisabled,
29
- 'aria-disabled': ariaDisabled === true || ariaDisabled === 'true',
30
- };
31
- const isAnyDisabled = disabledStateProps['aria-disabled'] || disabledStateProps.disabled;
32
- if (!isAnyDisabled) {
33
- (otherProps as any).onClick = onClick;
34
- (otherProps as any).onChange = onChange;
35
- }
36
- return { disabledStateProps, otherProps: otherProps as Output<TProps>['otherProps'], isAnyDisabled };
37
- }
@@ -1,32 +0,0 @@
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
- }
@@ -1,7 +0,0 @@
1
- /**
2
- * WARNING: All modules exported here are exposed to NPM in '@lumx/react/utils'.
3
- */
4
-
5
- export { ClickAwayProvider } from './ClickAwayProvider';
6
- export { Portal, type PortalProps, type PortalInit, PortalProvider, type PortalProviderProps } from './Portal';
7
- export { DisabledStateProvider, useDisabledStateContext } from './disabled';
@@ -1,4 +0,0 @@
1
- /**
2
- * Get current browser locale.
3
- */
4
- export const getCurrentLocale = (): string => navigator.languages?.[0] || navigator.language;
@@ -1,17 +0,0 @@
1
- import { parseLocale } from '@lumx/react/utils/locale/parseLocale';
2
-
3
- describe(parseLocale.name, () => {
4
- it('should parse various locale formats', () => {
5
- expect(parseLocale('en')).toEqual({ code: 'en', language: 'en' });
6
- expect(parseLocale('EN')).toEqual({ code: 'en', language: 'en' });
7
- expect(parseLocale('en-US')).toEqual({ code: 'en-US', language: 'en', region: 'US' });
8
- expect(parseLocale('en-us')).toEqual({ code: 'en-US', language: 'en', region: 'US' });
9
- expect(parseLocale('en_us')).toEqual({ code: 'en-US', language: 'en', region: 'US' });
10
- expect(parseLocale('EN-US')).toEqual({ code: 'en-US', language: 'en', region: 'US' });
11
- });
12
-
13
- it('should fail on invalid locale', () => {
14
- expect(parseLocale('-')).toBe(undefined);
15
- expect(parseLocale('-foo')).toBe(undefined);
16
- });
17
- });
@@ -1,23 +0,0 @@
1
- import { Locale } from '@lumx/react/utils/locale/types';
2
-
3
- /**
4
- * Parse locale code
5
- * @example
6
- * parseLocale('EN') // => { code: 'en', language: 'en' }
7
- * parseLocale('en_us') // => { code: 'en-US', language: 'en', region: 'US' }
8
- * parseLocale('EN-US') // => { code: 'en-US', language: 'en', region: 'US' }
9
- */
10
- export function parseLocale(locale: string): Locale | undefined {
11
- const [rawLanguage, rawRegion] = locale.split(/[-_]/);
12
- if (!rawLanguage) {
13
- return undefined;
14
- }
15
- const language = rawLanguage.toLowerCase();
16
- let region: string | undefined;
17
- let code = language;
18
- if (rawRegion) {
19
- region = rawRegion.toUpperCase();
20
- code += `-${region}`;
21
- }
22
- return { code, region, language };
23
- }
@@ -1,8 +0,0 @@
1
- export interface Locale {
2
- /** ISO locale code `lang-REGION` (ex: `en-US`) */
3
- code: string;
4
- /** ISO locale language code (ex: `en`) */
5
- language: string;
6
- /** ISO locale region code (ex: `US`) */
7
- region?: string;
8
- }
@@ -1,17 +0,0 @@
1
- /**
2
- * Clamp value in range.
3
- *
4
- * @param value Value to clamp.
5
- * @param min Minimum value.
6
- * @param max Maximum value.
7
- * @return Clamped value.
8
- */
9
- export const clamp = (value: number, min: number, max: number): number => {
10
- if (value < min) {
11
- return min;
12
- }
13
- if (value > max) {
14
- return max;
15
- }
16
- return value;
17
- };
@@ -1,25 +0,0 @@
1
- import { isEqual } from './isEqual';
2
-
3
- test(isEqual.name, () => {
4
- expect(isEqual('', '')).toBe(true);
5
- expect(isEqual(0, 0)).toBe(true);
6
- expect(isEqual(Number.POSITIVE_INFINITY, Number.POSITIVE_INFINITY)).toBe(true);
7
-
8
- expect(isEqual('', 0)).toBe(false);
9
-
10
- expect(isEqual({}, {})).toBe(true);
11
- expect(isEqual({ a: 1 }, { a: 1 })).toBe(true);
12
- expect(isEqual({ a: { a: 1 } }, { a: { a: 1 } })).toBe(true);
13
-
14
- expect(isEqual([], [])).toBe(true);
15
-
16
- expect(isEqual([1], [2])).toBe(false);
17
- expect(isEqual([1], [1, 2])).toBe(false);
18
- expect(isEqual([1, 2], [2, 1])).toBe(false);
19
-
20
- expect(isEqual({ a: 1 }, { a: 2 })).toBe(false);
21
- expect(isEqual({ a: 1 }, {})).toBe(false);
22
- expect(isEqual({}, { a: 1 })).toBe(false);
23
- expect(isEqual({ a: { a: 1 } }, { a: { a: 2 } })).toBe(false);
24
- expect(isEqual({ a: 1 }, { a: 1, b: 1 })).toBe(false);
25
- });
@@ -1,11 +0,0 @@
1
- /** Minimal recursive deep equal of JS values */
2
- export function isEqual(obj1: any, obj2: any): boolean {
3
- if (obj1 === obj2) return true;
4
- if (typeof obj1 === 'object' && typeof obj2 === 'object') {
5
- const keys1 = Object.keys(obj1);
6
- const keys2 = Object.keys(obj2);
7
- if (keys1.length !== keys2.length) return false;
8
- return keys1.every((key1) => isEqual(obj1[key1], obj2[key1]));
9
- }
10
- return false;
11
- }
@@ -1,27 +0,0 @@
1
- import partition from 'lodash/partition';
2
- import { partitionMulti } from './partitionMulti';
3
-
4
- describe('partitionMulti', () => {
5
- it('should act like partition for single predicate', () => {
6
- const data = [0, 1, 2, 3, 4, 5];
7
- const isEven = (n: number): boolean => n % 2 === 0;
8
-
9
- const expected = partition(data, isEven);
10
- const actual = partitionMulti(data, [isEven]);
11
-
12
- expect(actual).toEqual(expected);
13
- });
14
-
15
- it('should partition on multiple predicates', () => {
16
- type T = string | number | boolean;
17
- const data: T[] = ['a', 1, 'b', false, true];
18
- const isString = (s: T): boolean => typeof s === 'string';
19
- const isNumber = (s: T): boolean => typeof s === 'number';
20
-
21
- const [strings, numbers, others] = partitionMulti(data, [isString, isNumber]);
22
-
23
- expect(strings).toEqual(['a', 'b']);
24
- expect(numbers).toEqual([1]);
25
- expect(others).toEqual([false, true]);
26
- });
27
- });
@@ -1,29 +0,0 @@
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
-
7
- import { Predicate } from '@lumx/core/js/types';
8
-
9
- /**
10
- * Similar to lodash `partition` function but working with multiple predicates.
11
- *
12
- * @example
13
- * const isString = (s) => typeof s === 'string'
14
- * const isNumber = (s) => typeof s === 'number'
15
- * const [strings, numbers, others] = partitionMulti(['a', 1, 'b', false], [isString, isNumber])
16
- * //=> [['a', 'b'], [1], [false]]
17
- *
18
- * @param elements array of elements
19
- * @param predicates array of predicates to apply on elements
20
- * @return partitioned elements by the given predicates
21
- */
22
- export function partitionMulti<T>(elements: T[], predicates: Array<Predicate<T>>): T[][] {
23
- return reduce(
24
- predicates,
25
- (partitioned: T[][], predicate: Predicate<T>) =>
26
- concat(dropRight(partitioned), partition(last(partitioned), predicate)),
27
- [elements],
28
- );
29
- }
@@ -1,20 +0,0 @@
1
- import { useLayoutEffect } from 'react';
2
-
3
- /**
4
- * Helper component using useLayoutEffect to trigger a callback on before unmount.
5
- *
6
- * The callback must be wrapped in a React ref to avoid updating the `useLayoutEffect` before the un-mount
7
- */
8
- export const OnBeforeUnmount = ({ callbackRef }: { callbackRef: React.RefObject<(() => void) | undefined> }) => {
9
- useLayoutEffect(
10
- () => {
11
- return () => {
12
- // On unmount
13
- // eslint-disable-next-line react-hooks/exhaustive-deps
14
- callbackRef.current?.();
15
- };
16
- }, // eslint-disable-next-line react-hooks/exhaustive-deps
17
- [],
18
- );
19
- return null;
20
- };
@@ -1,153 +0,0 @@
1
- import React from 'react';
2
- import { render, screen } from '@testing-library/react';
3
- import userEvent from '@testing-library/user-event';
4
- import { RawClickable, RawClickableProps } from './RawClickable';
5
- import { CustomLink } from '../../stories/utils/CustomLink';
6
-
7
- /**
8
- * Mounts the component and returns common DOM elements / data needed in multiple tests.
9
- */
10
- const setup = (props: RawClickableProps<any>) => {
11
- render(<RawClickable {...props} data-testid="raw-element" />);
12
- const element = screen.getByTestId('raw-element');
13
- return { props, element };
14
- };
15
-
16
- describe(`<RawClickable>`, () => {
17
- describe('as a button', () => {
18
- it('should render a button by default', () => {
19
- const { element } = setup({ as: 'button', children: 'Click me' });
20
- expect(element.tagName).toBe('BUTTON');
21
- expect(element).toHaveAttribute('type', 'button');
22
- expect(screen.getByRole('button', { name: 'Click me' })).toBe(element);
23
- });
24
-
25
- it('should trigger onClick', async () => {
26
- const onClick = vi.fn();
27
- const { element } = setup({ as: 'button', children: 'Click me', onClick });
28
- await userEvent.click(element);
29
- expect(onClick).toHaveBeenCalledTimes(1);
30
- });
31
-
32
- it('should be disabled with `disabled` prop', async () => {
33
- const onClick = vi.fn();
34
- const { element } = setup({ as: 'button', children: 'Click me', onClick, disabled: true });
35
- expect(element).toBeDisabled();
36
- await userEvent.click(element);
37
- expect(onClick).not.toHaveBeenCalled();
38
- });
39
-
40
- it('should be disabled with `isDisabled` prop', async () => {
41
- const onClick = vi.fn();
42
- const { element } = setup({ as: 'button', children: 'Click me', onClick, isDisabled: true });
43
- expect(element).toBeDisabled();
44
- await userEvent.click(element);
45
- expect(onClick).not.toHaveBeenCalled();
46
- });
47
-
48
- it('should be aria-disabled with `aria-disabled` prop', async () => {
49
- const onClick = vi.fn();
50
- const { element } = setup({ as: 'button', children: 'Click me', onClick, 'aria-disabled': true });
51
- expect(element).not.toBeDisabled();
52
- expect(element).toHaveAttribute('aria-disabled', 'true');
53
- await userEvent.click(element);
54
- expect(onClick).not.toHaveBeenCalled();
55
- });
56
- });
57
-
58
- describe('as a link', () => {
59
- const href = 'https://example.com';
60
-
61
- it('should render a link with `href` prop', () => {
62
- const { element } = setup({ as: 'a', children: 'Click me', href });
63
- expect(element.tagName).toBe('A');
64
- expect(element).toHaveAttribute('href', href);
65
- expect(screen.getByRole('link', { name: 'Click me' })).toBe(element);
66
- });
67
-
68
- it('should trigger onClick', async () => {
69
- const onClick = vi.fn((evt: any) => evt.preventDefault());
70
- const { element } = setup({ as: 'a', children: 'Click me', href, onClick });
71
- await userEvent.click(element);
72
- expect(onClick).toHaveBeenCalledTimes(1);
73
- });
74
-
75
- it('should be disabled with `disabled` prop', async () => {
76
- const onClick = vi.fn();
77
- const { element } = setup({ as: 'a', children: 'Click me', href, onClick, disabled: true });
78
- expect(element).toHaveAttribute('aria-disabled', 'true');
79
- expect(element).toHaveAttribute('tabindex', '-1');
80
- await userEvent.click(element);
81
- expect(onClick).not.toHaveBeenCalled();
82
- });
83
-
84
- it('should be disabled with `isDisabled` prop', async () => {
85
- const onClick = vi.fn();
86
- const { element } = setup({ as: 'a', children: 'Click me', href, onClick, isDisabled: true });
87
- expect(element).toHaveAttribute('aria-disabled', 'true');
88
- expect(element).toHaveAttribute('tabindex', '-1');
89
- await userEvent.click(element);
90
- expect(onClick).not.toHaveBeenCalled();
91
- });
92
-
93
- it('should be aria-disabled with `aria-disabled` prop', async () => {
94
- const onClick = vi.fn();
95
- const { element } = setup({ as: 'a', children: 'Click me', href, onClick, 'aria-disabled': true });
96
- expect(element).toHaveAttribute('aria-disabled', 'true');
97
- await userEvent.click(element);
98
- expect(onClick).not.toHaveBeenCalled();
99
- });
100
- });
101
-
102
- describe('as a custom component', () => {
103
- it('should render a custom component with `linkAs` prop', () => {
104
- const { element } = setup({ as: CustomLink, children: 'Click me' });
105
- expect(element).toHaveAttribute('data-custom-link');
106
- });
107
-
108
- it('should trigger onClick', async () => {
109
- const onClick = vi.fn();
110
- const { element } = setup({ as: CustomLink, children: 'Click me', onClick });
111
- expect(element).toHaveAttribute('data-custom-link');
112
- await userEvent.click(element);
113
- expect(onClick).toHaveBeenCalledTimes(1);
114
- });
115
-
116
- it('should be disabled with `disabled` prop', async () => {
117
- const onClick = vi.fn();
118
- const { element } = setup({ as: CustomLink, children: 'Click me', onClick, disabled: true });
119
- expect(element).toHaveAttribute('data-custom-link');
120
- expect(element).toHaveAttribute('aria-disabled', 'true');
121
- expect(element).toHaveAttribute('tabindex', '-1');
122
- await userEvent.click(element);
123
- expect(onClick).not.toHaveBeenCalled();
124
- });
125
- });
126
-
127
- describe('prop forwarding', () => {
128
- it('should forward className', () => {
129
- const { element } = setup({ as: 'button', className: 'foo bar' });
130
- expect(element).toHaveClass('foo bar');
131
- });
132
-
133
- it('should forward ref and override type in button', () => {
134
- const ref = React.createRef<HTMLButtonElement>();
135
- const { element } = setup({ as: 'button', ref, type: 'submit' });
136
- expect(element).toHaveAttribute('type', 'submit');
137
- expect(ref.current).toBeInstanceOf(HTMLButtonElement);
138
- });
139
-
140
- it('should forward ref and override tabindex in link', () => {
141
- const ref = React.createRef<HTMLAnchorElement>();
142
- const { element } = setup({ as: 'a', ref, href: '#', tabIndex: -1 });
143
- expect(ref.current).toBeInstanceOf(HTMLAnchorElement);
144
- expect(element).toHaveAttribute('tabindex', '-1');
145
- });
146
-
147
- it('should forward ref to custom component', () => {
148
- const ref = React.createRef<HTMLAnchorElement>();
149
- setup({ as: CustomLink, ref });
150
- expect(ref.current).toBeInstanceOf(HTMLAnchorElement);
151
- });
152
- });
153
- });
@@ -1,65 +0,0 @@
1
- import { AriaAttributes, ElementType } from 'react';
2
- import { forwardRefPolymorphic } from '@lumx/react/utils/react/forwardRefPolymorphic';
3
- import { ComponentRef, HasPolymorphicAs } from '@lumx/react/utils/type';
4
- import { HasRequiredLinkHref } from '@lumx/react/utils/type/HasRequiredLinkHref';
5
-
6
- type ClickableElement = 'a' | 'button' | ElementType;
7
-
8
- type BaseClickableProps<E extends ClickableElement> = {
9
- children?: React.ReactNode;
10
- isDisabled?: boolean;
11
- disabled?: boolean;
12
- 'aria-disabled'?: AriaAttributes['aria-disabled'];
13
- onClick?: React.MouseEventHandler<E>;
14
- };
15
-
16
- export type RawClickableProps<E extends ClickableElement> = HasPolymorphicAs<E> &
17
- HasRequiredLinkHref<E> &
18
- BaseClickableProps<E>;
19
-
20
- /**
21
- * Render clickable element (link, button or custom element)
22
- * (also does some basic disabled state handling)
23
- */
24
- export const RawClickable = forwardRefPolymorphic(
25
- <E extends ClickableElement>(props: RawClickableProps<E>, ref: ComponentRef<E>) => {
26
- const {
27
- children,
28
- onClick,
29
- disabled,
30
- isDisabled = disabled,
31
- 'aria-disabled': ariaDisabled,
32
- as,
33
- ...forwardedProps
34
- } = props;
35
-
36
- const isAnyDisabled = isDisabled || ariaDisabled === 'true' || ariaDisabled === true;
37
-
38
- const Component = as as any;
39
- let clickableProps;
40
- if (Component === 'button') {
41
- clickableProps = { type: forwardedProps.type || 'button', disabled: isDisabled };
42
- } else {
43
- clickableProps = { tabIndex: isDisabled ? '-1' : forwardedProps.tabIndex };
44
- }
45
-
46
- return (
47
- <Component
48
- ref={ref}
49
- aria-disabled={isAnyDisabled || undefined}
50
- {...forwardedProps}
51
- {...clickableProps}
52
- onClick={(event: any) => {
53
- if (isAnyDisabled) {
54
- event.stopPropagation();
55
- event.preventDefault();
56
- return;
57
- }
58
- onClick?.(event);
59
- }}
60
- >
61
- {children}
62
- </Component>
63
- );
64
- },
65
- );
@@ -1,32 +0,0 @@
1
- import get from 'lodash/get';
2
- import { Children, Key, ReactChild, ReactNode, cloneElement, isValidElement } from 'react';
3
- import { isFragment } from 'react-is';
4
-
5
- /**
6
- * Flatten list of react nodes removing fragments and adding keys.
7
- * based on: https://github.com/grrowl/react-keyed-flatten-children/blob/5d421644a449765ddd62b659946196b4b5d7b135/index.ts
8
- *
9
- * @param children React nodes to flatten.
10
- * @return Flattened react nodes.
11
- * @deprecated This function was used to develop keyboard navigation in the List component,
12
- * but we will replace this with a better method that does not require to hack the children inspection
13
- *
14
- * TODO: remove List keyboard navigation once we have provided alternative component (Menu, Combobox, etc.),
15
- * remove this function and then remove react-is from the dependencies
16
- */
17
- export function flattenChildren(children: ReactNode) {
18
- function recur(nodes: ReactNode, keys: Key[] = []) {
19
- return Children.toArray(nodes).reduce((acc: ReactChild[], node, index) => {
20
- const nodeKeys = keys.concat(get(node, 'key') ?? index);
21
- if (isFragment(node)) {
22
- acc.push(...recur(node.props.children, nodeKeys));
23
- } else if (isValidElement(node)) {
24
- acc.push(cloneElement(node, { key: nodeKeys.join('.') }));
25
- } else if (typeof node === 'string' || typeof node === 'number') {
26
- acc.push(node);
27
- }
28
- return acc;
29
- }, []);
30
- }
31
- return recur(children);
32
- }
@@ -1,11 +0,0 @@
1
- import React, { type ReactNode, type ForwardedRef } from 'react';
2
- import type { Comp } from '../type';
3
-
4
- type ForwardRef = <P, T = HTMLElement, A = unknown>(
5
- render: (props: P, ref: ForwardedRef<T>) => ReactNode,
6
- ) => Comp<P, T> & A;
7
-
8
- /**
9
- * React.forwardRef but re-typed to attach some custom metadata on our components.
10
- */
11
- export const forwardRef = React.forwardRef as ForwardRef;
@@ -1,9 +0,0 @@
1
- import React, { type ElementType } from 'react';
2
- import type { ComponentRef } from '@lumx/react/utils/type';
3
-
4
- type ForwardRefPolymorphic = <E extends ElementType, P extends { as?: E }>(
5
- render: (props: P, ref: ComponentRef<E>) => React.ReactNode,
6
- ) => (props: P & React.ComponentProps<E> & { ref?: ComponentRef<E> }) => React.JSX.Element;
7
-
8
- /** Same as `React.forwardRef` but inferring Ref type from the `as` prop. */
9
- export const forwardRefPolymorphic = React.forwardRef as ForwardRefPolymorphic;
@@ -1,33 +0,0 @@
1
- import { Falsy } from '@lumx/react/utils/type';
2
- import { MutableRefObject, useMemo } 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
- }
23
-
24
- /**
25
- * Same as `mergeRefs` but memoized
26
- */
27
- export const useMergeRefs = <T>(...refs: Array<MutableRefObject<T | null> | FnRef<T> | Falsy>) => {
28
- return useMemo(
29
- () => mergeRefs(...refs),
30
- // eslint-disable-next-line react-hooks/exhaustive-deps
31
- refs,
32
- );
33
- };
@@ -1,17 +0,0 @@
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);
@@ -1,18 +0,0 @@
1
- import React from 'react';
2
-
3
- import { DOCUMENT } from '@lumx/react/constants';
4
- import type { Comp } from '@lumx/react/utils/type';
5
- /**
6
- * HOC component wrapping a component to skip render if predicate return falsy
7
- */
8
- export const skipRender = <P, T>(predicate: (props: P) => any, Component: Comp<P, T>) => {
9
- const Wrapper = React.forwardRef<T, P>((props, ref) => {
10
- if (!DOCUMENT) {
11
- // Can't render in SSR.
12
- return null;
13
- }
14
- return <Component ref={ref} {...props} />;
15
- });
16
- Wrapper.displayName = Component.displayName;
17
- return Wrapper;
18
- };
@@ -1,7 +0,0 @@
1
- import { MaybeElementOrRef } from '@lumx/react/utils/type';
2
-
3
- /** Unref a react ref or element */
4
- export function unref(maybeElement: MaybeElementOrRef<HTMLElement>) {
5
- if (maybeElement instanceof HTMLElement) return maybeElement;
6
- return maybeElement?.current;
7
- }