@react-md/core 1.0.0-next.2 → 1.0.0-next.4

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 (1804) hide show
  1. package/.turbo/turbo-build.log +5 -5
  2. package/.turbo/turbo-lint.log +12 -0
  3. package/.turbo/turbo-test.log +179 -0
  4. package/.turbo/turbo-typecheck.log +4 -0
  5. package/CHANGELOG.md +109 -0
  6. package/coverage/clover.xml +529 -3
  7. package/coverage/coverage-final.json +4 -1
  8. package/coverage/lcov-report/Avatar.tsx.html +472 -0
  9. package/coverage/lcov-report/IconRotator.tsx.html +322 -0
  10. package/coverage/lcov-report/ListItem.tsx.html +892 -0
  11. package/coverage/lcov-report/ListItemLink.tsx.html +616 -0
  12. package/coverage/lcov-report/Portal.tsx.html +223 -0
  13. package/coverage/lcov-report/PortalContainerProvider.tsx.html +367 -0
  14. package/coverage/lcov-report/SkeletonPlaceholder.tsx.html +613 -0
  15. package/coverage/lcov-report/Tab.tsx.html +261 -147
  16. package/coverage/lcov-report/TreeGroup.tsx.html +313 -0
  17. package/coverage/lcov-report/app-bar/AppBar.tsx.html +178 -28
  18. package/coverage/lcov-report/app-bar/index.html +7 -7
  19. package/coverage/lcov-report/button/TooltippedButton.tsx.html +445 -0
  20. package/coverage/lcov-report/button/index.html +10 -10
  21. package/coverage/lcov-report/card/Card.tsx.html +349 -0
  22. package/coverage/lcov-report/card/CardContent.tsx.html +223 -0
  23. package/coverage/lcov-report/card/ClickableCard.tsx.html +400 -0
  24. package/coverage/lcov-report/card/index.html +21 -21
  25. package/coverage/lcov-report/card/styles.ts.html +428 -392
  26. package/coverage/lcov-report/cssUtils.ts.html +86 -59
  27. package/coverage/lcov-report/draggable/index.html +21 -36
  28. package/coverage/lcov-report/draggable/useDraggable.ts.html +377 -368
  29. package/coverage/lcov-report/draggable/utils.ts.html +96 -195
  30. package/coverage/lcov-report/expansion-panel/ExpansionList.tsx.html +211 -0
  31. package/coverage/lcov-report/expansion-panel/ExpansionPanel.tsx.html +12 -15
  32. package/coverage/lcov-report/expansion-panel/index.html +34 -19
  33. package/coverage/lcov-report/expansion-panel/useExpansionPanels.ts.html +928 -0
  34. package/coverage/lcov-report/form/MenuItemInputToggle.tsx.html +2 -2
  35. package/coverage/lcov-report/form/Select.tsx.html +1663 -0
  36. package/coverage/lcov-report/form/Slider.tsx.html +163 -40
  37. package/coverage/lcov-report/form/index.html +21 -21
  38. package/coverage/lcov-report/getListItemHeight.ts.html +298 -0
  39. package/coverage/lcov-report/icon/FontIcon.tsx.html +28 -28
  40. package/coverage/lcov-report/icon/index.html +1 -1
  41. package/coverage/lcov-report/index.html +56 -11
  42. package/coverage/lcov-report/interaction/UserInteractionModeProvider.tsx.html +679 -0
  43. package/coverage/lcov-report/interaction/config.ts.html +181 -0
  44. package/coverage/lcov-report/interaction/index.html +33 -18
  45. package/coverage/lcov-report/list/List.tsx.html +490 -0
  46. package/coverage/lcov-report/list/ListItem.tsx.html +886 -0
  47. package/coverage/lcov-report/list/ListItemAddon.tsx.html +286 -0
  48. package/coverage/lcov-report/list/ListItemChildren.tsx.html +445 -0
  49. package/coverage/lcov-report/list/ListItemLink.tsx.html +5 -5
  50. package/coverage/lcov-report/list/index.html +81 -6
  51. package/coverage/lcov-report/list/listItemStyles.ts.html +703 -0
  52. package/coverage/lcov-report/media-queries/appSize.ts.html +1 -1
  53. package/coverage/lcov-report/media-queries/index.html +1 -1
  54. package/coverage/lcov-report/menu/Menu.tsx.html +37 -19
  55. package/coverage/lcov-report/menu/index.html +14 -44
  56. package/coverage/lcov-report/sheet/index.html +8 -8
  57. package/coverage/lcov-report/sheet/styles.ts.html +376 -0
  58. package/coverage/lcov-report/skeletonPlaceholderUtils.ts.html +400 -0
  59. package/coverage/lcov-report/src/CoreProviders.tsx.html +20 -20
  60. package/coverage/lcov-report/src/NoSsr.tsx.html +1 -1
  61. package/coverage/lcov-report/src/SsrProvider.tsx.html +10 -10
  62. package/coverage/lcov-report/src/app-bar/AppBar.tsx.html +143 -23
  63. package/coverage/lcov-report/src/app-bar/AppBarTitle.tsx.html +1 -1
  64. package/coverage/lcov-report/src/app-bar/index.html +5 -5
  65. package/coverage/lcov-report/src/avatar/Avatar.tsx.html +2 -2
  66. package/coverage/lcov-report/src/avatar/index.html +1 -1
  67. package/coverage/lcov-report/src/avatar/styles.ts.html +1 -1
  68. package/coverage/lcov-report/src/badge/Badge.tsx.html +1 -1
  69. package/coverage/lcov-report/src/badge/index.html +1 -1
  70. package/coverage/lcov-report/src/box/Box.tsx.html +1 -1
  71. package/coverage/lcov-report/src/box/index.html +23 -8
  72. package/coverage/lcov-report/src/box/styles.ts.html +46 -46
  73. package/coverage/lcov-report/src/button/AsyncButton.tsx.html +1 -1
  74. package/coverage/lcov-report/src/button/Button.tsx.html +84 -84
  75. package/coverage/lcov-report/src/button/ButtonUnstyled.tsx.html +1 -1
  76. package/coverage/lcov-report/src/button/FloatingActionButton.tsx.html +11 -11
  77. package/coverage/lcov-report/src/button/TooltippedButton.tsx.html +445 -0
  78. package/coverage/lcov-report/src/button/buttonStyles.ts.html +52 -52
  79. package/coverage/lcov-report/src/button/buttonUnstyledStyles.ts.html +1 -1
  80. package/coverage/lcov-report/src/button/index.html +83 -8
  81. package/coverage/lcov-report/src/card/Card.tsx.html +37 -31
  82. package/coverage/lcov-report/src/card/CardContent.tsx.html +4 -4
  83. package/coverage/lcov-report/src/card/CardFooter.tsx.html +1 -1
  84. package/coverage/lcov-report/src/card/CardHeader.tsx.html +1 -1
  85. package/coverage/lcov-report/src/card/CardSubtitle.tsx.html +1 -1
  86. package/coverage/lcov-report/src/card/CardTitle.tsx.html +1 -1
  87. package/coverage/lcov-report/src/card/ClickableCard.tsx.html +400 -0
  88. package/coverage/lcov-report/src/card/index.html +24 -9
  89. package/coverage/lcov-report/src/card/styles.ts.html +58 -31
  90. package/coverage/lcov-report/src/chip/Chip.tsx.html +1 -1
  91. package/coverage/lcov-report/src/chip/index.html +7 -7
  92. package/coverage/lcov-report/src/chip/styles.ts.html +9 -12
  93. package/coverage/lcov-report/src/cssUtils.ts.html +53 -53
  94. package/coverage/lcov-report/src/delegateEvent.ts.html +109 -109
  95. package/coverage/lcov-report/src/dialog/Dialog.tsx.html +1 -1
  96. package/coverage/lcov-report/src/dialog/DialogContainer.tsx.html +1 -1
  97. package/coverage/lcov-report/src/dialog/DialogContent.tsx.html +1 -1
  98. package/coverage/lcov-report/src/dialog/DialogFooter.tsx.html +1 -1
  99. package/coverage/lcov-report/src/dialog/DialogHeader.tsx.html +1 -1
  100. package/coverage/lcov-report/src/dialog/DialogTitle.tsx.html +1 -1
  101. package/coverage/lcov-report/src/dialog/FixedDialog.tsx.html +1 -1
  102. package/coverage/lcov-report/src/dialog/NestedDialogProvider.ts.html +1 -1
  103. package/coverage/lcov-report/src/dialog/index.html +129 -9
  104. package/coverage/lcov-report/src/dialog/styles.ts.html +1 -1
  105. package/coverage/lcov-report/src/divider/Divider.tsx.html +4 -7
  106. package/coverage/lcov-report/src/divider/index.html +5 -5
  107. package/coverage/lcov-report/src/divider/styles.ts.html +1 -1
  108. package/coverage/lcov-report/src/draggable/index.html +27 -27
  109. package/coverage/lcov-report/src/draggable/useDraggable.ts.html +47 -44
  110. package/coverage/lcov-report/src/draggable/utils.ts.html +29 -131
  111. package/coverage/lcov-report/src/expansion-panel/ExpansionList.tsx.html +1 -1
  112. package/coverage/lcov-report/src/expansion-panel/ExpansionPanel.tsx.html +1 -1
  113. package/coverage/lcov-report/src/expansion-panel/ExpansionPanelHeader.tsx.html +1 -1
  114. package/coverage/lcov-report/src/expansion-panel/index.html +8 -8
  115. package/coverage/lcov-report/src/expansion-panel/useExpansionList.ts.html +1 -1
  116. package/coverage/lcov-report/src/expansion-panel/useExpansionPanels.ts.html +36 -24
  117. package/coverage/lcov-report/src/focus/index.html +1 -1
  118. package/coverage/lcov-report/src/focus/useFocusContainer.ts.html +1 -1
  119. package/coverage/lcov-report/src/focus/utils.ts.html +1 -1
  120. package/coverage/lcov-report/src/form/Checkbox.tsx.html +1 -1
  121. package/coverage/lcov-report/src/form/Fieldset.tsx.html +1 -1
  122. package/coverage/lcov-report/src/form/FileInput.tsx.html +1 -1
  123. package/coverage/lcov-report/src/form/Form.tsx.html +1 -1
  124. package/coverage/lcov-report/src/form/FormMessage.tsx.html +1 -1
  125. package/coverage/lcov-report/src/form/FormMessageContainer.tsx.html +5 -5
  126. package/coverage/lcov-report/src/form/FormMessageCounter.tsx.html +1 -1
  127. package/coverage/lcov-report/src/form/InputToggle.tsx.html +110 -110
  128. package/coverage/lcov-report/src/form/InputToggleIcon.tsx.html +63 -63
  129. package/coverage/lcov-report/src/form/Label.tsx.html +98 -98
  130. package/coverage/lcov-report/src/form/Legend.tsx.html +1 -1
  131. package/coverage/lcov-report/src/form/MenuItemCheckbox.tsx.html +1 -1
  132. package/coverage/lcov-report/src/form/MenuItemFileInput.tsx.html +1 -1
  133. package/coverage/lcov-report/src/form/MenuItemInputToggle.tsx.html +2 -2
  134. package/coverage/lcov-report/src/form/MenuItemRadio.tsx.html +1 -1
  135. package/coverage/lcov-report/src/form/MenuItemSwitch.tsx.html +1 -1
  136. package/coverage/lcov-report/src/form/MenuItemTextField.tsx.html +1 -1
  137. package/coverage/lcov-report/src/form/NativeSelect.tsx.html +1 -1
  138. package/coverage/lcov-report/src/form/OptGroup.tsx.html +1 -1
  139. package/coverage/lcov-report/src/form/Option.tsx.html +1 -1
  140. package/coverage/lcov-report/src/form/Password.tsx.html +1 -1
  141. package/coverage/lcov-report/src/form/Radio.tsx.html +3 -3
  142. package/coverage/lcov-report/src/form/Select.tsx.html +29 -5
  143. package/coverage/lcov-report/src/form/SelectValue.tsx.html +1 -1
  144. package/coverage/lcov-report/src/form/Slider.tsx.html +1 -1
  145. package/coverage/lcov-report/src/form/SliderContainer.tsx.html +1 -1
  146. package/coverage/lcov-report/src/form/SliderMark.tsx.html +1 -1
  147. package/coverage/lcov-report/src/form/SliderMarkLabel.tsx.html +1 -1
  148. package/coverage/lcov-report/src/form/SliderThumb.tsx.html +1 -1
  149. package/coverage/lcov-report/src/form/SliderTrack.tsx.html +1 -1
  150. package/coverage/lcov-report/src/form/SliderValueMarks.tsx.html +1 -1
  151. package/coverage/lcov-report/src/form/SliderValueTooltip.tsx.html +1 -1
  152. package/coverage/lcov-report/src/form/Switch.tsx.html +1 -1
  153. package/coverage/lcov-report/src/form/SwitchTrack.tsx.html +1 -1
  154. package/coverage/lcov-report/src/form/TextArea.tsx.html +2 -2
  155. package/coverage/lcov-report/src/form/TextField.tsx.html +1 -1
  156. package/coverage/lcov-report/src/form/TextFieldAddon.tsx.html +1 -1
  157. package/coverage/lcov-report/src/form/TextFieldContainer.tsx.html +1 -1
  158. package/coverage/lcov-report/src/form/TextFieldContainerStyles.ts.html +8 -8
  159. package/coverage/lcov-report/src/form/fileUtils.ts.html +1 -1
  160. package/coverage/lcov-report/src/form/formConfig.ts.html +1 -1
  161. package/coverage/lcov-report/src/form/formMessageStyles.ts.html +1 -1
  162. package/coverage/lcov-report/src/form/index.html +940 -10
  163. package/coverage/lcov-report/src/form/inputToggleStyles.ts.html +30 -30
  164. package/coverage/lcov-report/src/form/nativeSelectStyles.ts.html +1 -1
  165. package/coverage/lcov-report/src/form/optionStyles.ts.html +1 -1
  166. package/coverage/lcov-report/src/form/passwordStyles.ts.html +1 -1
  167. package/coverage/lcov-report/src/form/selectStyles.ts.html +1 -1
  168. package/coverage/lcov-report/src/form/selectUtils.ts.html +1 -1
  169. package/coverage/lcov-report/src/form/sliderUtils.ts.html +1 -1
  170. package/coverage/lcov-report/src/form/switchStyles.ts.html +1 -1
  171. package/coverage/lcov-report/src/form/textAreaStyles.ts.html +3 -3
  172. package/coverage/lcov-report/src/form/textFieldStyles.ts.html +1 -1
  173. package/coverage/lcov-report/src/form/useCheckboxGroup.ts.html +1 -1
  174. package/coverage/lcov-report/src/form/useFileUpload.ts.html +1 -1
  175. package/coverage/lcov-report/src/form/useListboxProvider.ts.html +1 -1
  176. package/coverage/lcov-report/src/form/useNumberField.ts.html +1 -1
  177. package/coverage/lcov-report/src/form/useRadioGroup.ts.html +47 -47
  178. package/coverage/lcov-report/src/form/useRangeSlider.ts.html +1 -1
  179. package/coverage/lcov-report/src/form/useResizingTextArea.ts.html +1 -1
  180. package/coverage/lcov-report/src/form/useSlider.ts.html +1 -1
  181. package/coverage/lcov-report/src/form/useTextField.ts.html +1 -1
  182. package/coverage/lcov-report/src/form/utils.ts.html +1 -1
  183. package/coverage/lcov-report/src/form/validation.ts.html +1 -1
  184. package/coverage/lcov-report/src/hoverMode/index.html +1 -1
  185. package/coverage/lcov-report/src/hoverMode/useHoverMode.ts.html +98 -98
  186. package/coverage/lcov-report/src/hoverMode/useHoverModeProvider.ts.html +19 -19
  187. package/coverage/lcov-report/src/icon/FontIcon.tsx.html +28 -28
  188. package/coverage/lcov-report/src/icon/IconRotator.tsx.html +5 -8
  189. package/coverage/lcov-report/src/icon/MaterialIcon.tsx.html +1 -1
  190. package/coverage/lcov-report/src/icon/MaterialSymbol.tsx.html +1 -1
  191. package/coverage/lcov-report/src/icon/SVGIcon.tsx.html +1 -1
  192. package/coverage/lcov-report/src/icon/TextIconSpacing.tsx.html +1 -1
  193. package/coverage/lcov-report/src/icon/iconConfig.tsx.html +8 -8
  194. package/coverage/lcov-report/src/icon/index.html +7 -7
  195. package/coverage/lcov-report/src/icon/material.ts.html +1 -1
  196. package/coverage/lcov-report/src/icon/materialConfig.ts.html +1 -1
  197. package/coverage/lcov-report/src/icon/styles.ts.html +38 -38
  198. package/coverage/lcov-report/src/index.html +354 -9
  199. package/coverage/lcov-report/src/interaction/Ripple.tsx.html +1 -1
  200. package/coverage/lcov-report/src/interaction/RippleContainer.tsx.html +1 -1
  201. package/coverage/lcov-report/src/interaction/UserInteractionModeProvider.tsx.html +87 -87
  202. package/coverage/lcov-report/src/interaction/config.ts.html +7 -7
  203. package/coverage/lcov-report/src/interaction/index.html +1 -1
  204. package/coverage/lcov-report/src/interaction/useElementInteraction.tsx.html +123 -123
  205. package/coverage/lcov-report/src/interaction/useHigherContrastChildren.tsx.html +17 -17
  206. package/coverage/lcov-report/src/interaction/utils.ts.html +1 -1
  207. package/coverage/lcov-report/src/layout/LayoutAppBar.tsx.html +1 -1
  208. package/coverage/lcov-report/src/layout/LayoutNav.tsx.html +60 -60
  209. package/coverage/lcov-report/src/layout/LayoutWindowSplitter.tsx.html +1 -1
  210. package/coverage/lcov-report/src/layout/Main.tsx.html +1 -1
  211. package/coverage/lcov-report/src/layout/index.html +15 -15
  212. package/coverage/lcov-report/src/layout/layoutNavStyles.ts.html +5 -5
  213. package/coverage/lcov-report/src/layout/layoutWindowSplitterStyles.ts.html +1 -1
  214. package/coverage/lcov-report/src/layout/mainStyles.ts.html +1 -1
  215. package/coverage/lcov-report/src/layout/useExpandableLayout.ts.html +1 -1
  216. package/coverage/lcov-report/src/layout/useHorizontalLayoutTransition.ts.html +1 -1
  217. package/coverage/lcov-report/src/layout/useLayoutAppBarHeight.ts.html +20 -32
  218. package/coverage/lcov-report/src/layout/useLayoutTree.ts.html +1 -1
  219. package/coverage/lcov-report/src/layout/useLayoutWindowSplitter.ts.html +1 -1
  220. package/coverage/lcov-report/src/layout/useMainTabIndex.ts.html +1 -1
  221. package/coverage/lcov-report/src/layout/useResizableLayout.ts.html +1 -1
  222. package/coverage/lcov-report/src/layout/useTemporaryLayout.ts.html +1 -1
  223. package/coverage/lcov-report/src/link/Link.tsx.html +1 -1
  224. package/coverage/lcov-report/src/link/SkipToMainContent.tsx.html +1 -1
  225. package/coverage/lcov-report/src/link/index.html +1 -1
  226. package/coverage/lcov-report/src/link/styles.ts.html +1 -1
  227. package/coverage/lcov-report/src/list/List.tsx.html +30 -30
  228. package/coverage/lcov-report/src/list/ListItem.tsx.html +37 -16
  229. package/coverage/lcov-report/src/list/ListItemAddon.tsx.html +13 -7
  230. package/coverage/lcov-report/src/list/ListItemChildren.tsx.html +12 -6
  231. package/coverage/lcov-report/src/list/ListItemLink.tsx.html +4 -4
  232. package/coverage/lcov-report/src/list/ListItemText.tsx.html +1 -1
  233. package/coverage/lcov-report/src/list/ListSubheader.tsx.html +1 -1
  234. package/coverage/lcov-report/src/list/getListItemHeight.ts.html +1 -1
  235. package/coverage/lcov-report/src/list/index.html +11 -11
  236. package/coverage/lcov-report/src/list/listItemStyles.ts.html +39 -9
  237. package/coverage/lcov-report/src/media-queries/AppSizeProvider.tsx.html +54 -54
  238. package/coverage/lcov-report/src/media-queries/appSize.ts.html +1 -1
  239. package/coverage/lcov-report/src/media-queries/index.html +1 -1
  240. package/coverage/lcov-report/src/media-queries/useMediaQuery.ts.html +25 -25
  241. package/coverage/lcov-report/src/menu/DropdownMenu.tsx.html +1 -1
  242. package/coverage/lcov-report/src/menu/Menu.tsx.html +2 -2
  243. package/coverage/lcov-report/src/menu/MenuBar.tsx.html +1 -1
  244. package/coverage/lcov-report/src/menu/MenuButton.tsx.html +1 -1
  245. package/coverage/lcov-report/src/menu/MenuConfigurationProvider.tsx.html +1 -1
  246. package/coverage/lcov-report/src/menu/MenuItem.tsx.html +1 -1
  247. package/coverage/lcov-report/src/menu/MenuItemButton.tsx.html +1 -1
  248. package/coverage/lcov-report/src/menu/MenuItemGroup.tsx.html +1 -1
  249. package/coverage/lcov-report/src/menu/MenuItemSeparator.tsx.html +1 -1
  250. package/coverage/lcov-report/src/menu/MenuSheet.tsx.html +1 -1
  251. package/coverage/lcov-report/src/menu/MenuVisibilityProvider.tsx.html +1 -1
  252. package/coverage/lcov-report/src/menu/MenuWidget.tsx.html +1 -1
  253. package/coverage/lcov-report/src/menu/MenuWidgetKeyboardProvider.tsx.html +1 -1
  254. package/coverage/lcov-report/src/menu/index.html +1 -1
  255. package/coverage/lcov-report/src/menu/useContextMenu.ts.html +1 -1
  256. package/coverage/lcov-report/src/menu/useMenuBarProvider.ts.html +1 -1
  257. package/coverage/lcov-report/src/menu/utils.ts.html +1 -1
  258. package/coverage/lcov-report/src/movement/constants.ts.html +1 -1
  259. package/coverage/lcov-report/src/movement/findMatchIndex.ts.html +1 -1
  260. package/coverage/lcov-report/src/movement/index.html +1 -1
  261. package/coverage/lcov-report/src/movement/useKeyboardMovementProvider.ts.html +3 -3
  262. package/coverage/lcov-report/src/movement/utils.ts.html +1 -1
  263. package/coverage/lcov-report/src/overlay/Overlay.tsx.html +1 -1
  264. package/coverage/lcov-report/src/overlay/index.html +1 -1
  265. package/coverage/lcov-report/src/overlay/overlayStyles.ts.html +1 -1
  266. package/coverage/lcov-report/src/portal/Portal.tsx.html +7 -7
  267. package/coverage/lcov-report/src/portal/PortalContainerProvider.tsx.html +59 -35
  268. package/coverage/lcov-report/src/portal/index.html +7 -7
  269. package/coverage/lcov-report/src/positioning/constants.ts.html +1 -1
  270. package/coverage/lcov-report/src/positioning/createHorizontalPosition.ts.html +47 -47
  271. package/coverage/lcov-report/src/positioning/createVerticalPosition.ts.html +55 -55
  272. package/coverage/lcov-report/src/positioning/getFixedPosition.ts.html +89 -89
  273. package/coverage/lcov-report/src/positioning/index.html +1 -1
  274. package/coverage/lcov-report/src/positioning/useFixedPositioning.ts.html +193 -193
  275. package/coverage/lcov-report/src/positioning/utils.ts.html +59 -59
  276. package/coverage/lcov-report/src/progress/CircularProgress.tsx.html +3 -3
  277. package/coverage/lcov-report/src/progress/LinearProgress.tsx.html +3 -3
  278. package/coverage/lcov-report/src/progress/getProgressA11y.ts.html +1 -1
  279. package/coverage/lcov-report/src/progress/index.html +20 -5
  280. package/coverage/lcov-report/src/responsive-item/ResponsiveItemContainer.tsx.html +1 -1
  281. package/coverage/lcov-report/src/responsive-item/ResponsiveItemOverlay.tsx.html +1 -1
  282. package/coverage/lcov-report/src/responsive-item/index.html +1 -1
  283. package/coverage/lcov-report/src/responsive-item/styles.ts.html +1 -1
  284. package/coverage/lcov-report/src/scroll/ScrollLock.tsx.html +1 -1
  285. package/coverage/lcov-report/src/scroll/getScrollbarWidth.ts.html +1 -1
  286. package/coverage/lcov-report/src/scroll/index.html +1 -1
  287. package/coverage/lcov-report/src/scroll/useScrollLock.ts.html +1 -1
  288. package/coverage/lcov-report/src/segmented-button/SegmentedButton.tsx.html +1 -1
  289. package/coverage/lcov-report/src/segmented-button/SegmentedButtonContainer.tsx.html +1 -1
  290. package/coverage/lcov-report/src/segmented-button/index.html +1 -1
  291. package/coverage/lcov-report/src/segmented-button/segmentedButtonContainerStyles.ts.html +1 -1
  292. package/coverage/lcov-report/src/segmented-button/segmentedButtonStyles.ts.html +1 -1
  293. package/coverage/lcov-report/src/sheet/Sheet.tsx.html +1 -1
  294. package/coverage/lcov-report/src/sheet/index.html +5 -5
  295. package/coverage/lcov-report/src/sheet/styles.ts.html +45 -48
  296. package/coverage/lcov-report/src/snackbar/DefaultToastRenderer.tsx.html +80 -80
  297. package/coverage/lcov-report/src/snackbar/Snackbar.tsx.html +21 -45
  298. package/coverage/lcov-report/src/snackbar/Toast.tsx.html +108 -93
  299. package/coverage/lcov-report/src/snackbar/ToastActionButton.tsx.html +1 -1
  300. package/coverage/lcov-report/src/snackbar/ToastCloseButton.tsx.html +1 -1
  301. package/coverage/lcov-report/src/snackbar/ToastContent.tsx.html +48 -48
  302. package/coverage/lcov-report/src/snackbar/ToastManager.tsx.html +278 -275
  303. package/coverage/lcov-report/src/snackbar/ToastManagerProvider.tsx.html +6 -6
  304. package/coverage/lcov-report/src/snackbar/index.html +19 -19
  305. package/coverage/lcov-report/src/snackbar/snackbarStyles.ts.html +15 -15
  306. package/coverage/lcov-report/src/snackbar/toastContentStyles.ts.html +14 -14
  307. package/coverage/lcov-report/src/snackbar/toastStyles.ts.html +27 -27
  308. package/coverage/lcov-report/src/snackbar/useCurrentToastActions.ts.html +1 -1
  309. package/coverage/lcov-report/src/suspense/CircularProgressSuspense.tsx.html +1 -1
  310. package/coverage/lcov-report/src/suspense/NullSuspense.tsx.html +1 -1
  311. package/coverage/lcov-report/src/suspense/index.html +20 -5
  312. package/coverage/lcov-report/src/table/Table.tsx.html +45 -114
  313. package/coverage/lcov-report/src/table/TableBody.tsx.html +43 -43
  314. package/coverage/lcov-report/src/table/TableCell.tsx.html +109 -298
  315. package/coverage/lcov-report/src/table/TableCellContent.tsx.html +81 -27
  316. package/coverage/lcov-report/src/table/TableCheckbox.tsx.html +16 -10
  317. package/coverage/lcov-report/src/table/TableConfigurationProvider.tsx.html +20 -20
  318. package/coverage/lcov-report/src/table/TableContainer.tsx.html +7 -28
  319. package/coverage/lcov-report/src/table/TableContainerProvider.tsx.html +1 -1
  320. package/coverage/lcov-report/src/table/TableFooter.tsx.html +64 -43
  321. package/coverage/lcov-report/src/table/TableHeader.tsx.html +41 -92
  322. package/coverage/lcov-report/src/table/TableRadio.tsx.html +676 -0
  323. package/coverage/lcov-report/src/table/TableRow.tsx.html +38 -119
  324. package/coverage/lcov-report/src/table/index.html +151 -46
  325. package/coverage/lcov-report/src/table/tableCellStyles.ts.html +334 -0
  326. package/coverage/lcov-report/src/table/tableContainerStyles.ts.html +142 -0
  327. package/coverage/lcov-report/src/table/tableFooterStyles.ts.html +166 -0
  328. package/coverage/lcov-report/src/table/tableHeaderStyles.ts.html +172 -0
  329. package/coverage/lcov-report/src/table/tableRowStyles.ts.html +169 -0
  330. package/coverage/lcov-report/src/table/tableStyles.ts.html +157 -0
  331. package/coverage/lcov-report/src/tabs/Tab.tsx.html +263 -143
  332. package/coverage/lcov-report/src/tabs/TabList.tsx.html +1 -1
  333. package/coverage/lcov-report/src/tabs/TabListScrollButton.tsx.html +1 -1
  334. package/coverage/lcov-report/src/tabs/index.html +25 -25
  335. package/coverage/lcov-report/src/tabs/tabIndicatorStyles.ts.html +37 -7
  336. package/coverage/lcov-report/src/tabs/tabListScrollButtonStyles.ts.html +1 -1
  337. package/coverage/lcov-report/src/tabs/tabListStyles.ts.html +2 -2
  338. package/coverage/lcov-report/src/tabs/tabStyles.ts.html +64 -28
  339. package/coverage/lcov-report/src/tabs/useTabList.ts.html +44 -38
  340. package/coverage/lcov-report/src/tabs/useTabs.ts.html +1 -1
  341. package/coverage/lcov-report/src/tabs/utils.ts.html +3 -3
  342. package/coverage/lcov-report/src/test-utils/IntersectionObserver.ts.html +1 -1
  343. package/coverage/lcov-report/src/test-utils/ResizeObserver.ts.html +205 -205
  344. package/coverage/lcov-report/src/test-utils/data-testid.ts.html +1 -1
  345. package/coverage/lcov-report/src/test-utils/drag.ts.html +1 -1
  346. package/coverage/lcov-report/src/test-utils/index.html +4 -4
  347. package/coverage/lcov-report/src/test-utils/jest-setup.ts.html +9 -9
  348. package/coverage/lcov-report/src/test-utils/matchMedia.ts.html +4 -4
  349. package/coverage/lcov-report/src/test-utils/polyfills/IntersectionObserver.ts.html +4 -4
  350. package/coverage/lcov-report/src/test-utils/polyfills/ResizeObserver.ts.html +3 -3
  351. package/coverage/lcov-report/src/test-utils/polyfills/index.html +1 -1
  352. package/coverage/lcov-report/src/test-utils/polyfills/matchMedia.ts.html +6 -6
  353. package/coverage/lcov-report/src/test-utils/polyfills/offsetParent.ts.html +14 -14
  354. package/coverage/lcov-report/src/test-utils/polyfills/scrollIntoView.ts.html +5 -5
  355. package/coverage/lcov-report/src/test-utils/render.tsx.html +21 -21
  356. package/coverage/lcov-report/src/test-utils/timers.ts.html +1 -1
  357. package/coverage/lcov-report/src/theme/LocalStorageColorSchemeProvider.tsx.html +1 -1
  358. package/coverage/lcov-report/src/theme/ThemeProvider.tsx.html +1 -1
  359. package/coverage/lcov-report/src/theme/colors.ts.html +1 -1
  360. package/coverage/lcov-report/src/theme/cssVars.ts.html +1 -1
  361. package/coverage/lcov-report/src/theme/index.html +1 -1
  362. package/coverage/lcov-report/src/theme/useCSSVariables.ts.html +25 -25
  363. package/coverage/lcov-report/src/theme/useColorScheme.ts.html +1 -1
  364. package/coverage/lcov-report/src/theme/useColorSchemeMetaTag.ts.html +1 -1
  365. package/coverage/lcov-report/src/theme/useColorSchemeProvider.ts.html +1 -1
  366. package/coverage/lcov-report/src/theme/usePrefersColorScheme.ts.html +1 -1
  367. package/coverage/lcov-report/src/theme/utils.ts.html +1 -1
  368. package/coverage/lcov-report/src/tooltip/Tooltip.tsx.html +62 -62
  369. package/coverage/lcov-report/src/tooltip/TooltipHoverModeProvider.tsx.html +3 -3
  370. package/coverage/lcov-report/src/tooltip/constants.ts.html +1 -1
  371. package/coverage/lcov-report/src/tooltip/index.html +9 -9
  372. package/coverage/lcov-report/src/tooltip/tooltipStyles.ts.html +12 -12
  373. package/coverage/lcov-report/src/tooltip/useTooltip.ts.html +243 -222
  374. package/coverage/lcov-report/src/tooltip/useTooltipPosition.ts.html +27 -27
  375. package/coverage/lcov-report/src/tooltip/utils.ts.html +22 -22
  376. package/coverage/lcov-report/src/transition/CSSTransition.tsx.html +1 -1
  377. package/coverage/lcov-report/src/transition/Collapse.tsx.html +1 -1
  378. package/coverage/lcov-report/src/transition/CrossFade.tsx.html +1 -1
  379. package/coverage/lcov-report/src/transition/ScaleTransition.tsx.html +1 -1
  380. package/coverage/lcov-report/src/transition/SkeletonPlaceholder.tsx.html +374 -338
  381. package/coverage/lcov-report/src/transition/Slide.tsx.html +1 -1
  382. package/coverage/lcov-report/src/transition/SlideContainer.tsx.html +1 -1
  383. package/coverage/lcov-report/src/transition/collapseStyles.ts.html +13 -13
  384. package/coverage/lcov-report/src/transition/config.ts.html +5 -5
  385. package/coverage/lcov-report/src/transition/index.html +47 -32
  386. package/coverage/lcov-report/src/transition/maxWidthTransition.ts.html +1 -1
  387. package/coverage/lcov-report/src/transition/skeletonPlaceholderUtils.ts.html +400 -0
  388. package/coverage/lcov-report/src/transition/useCSSTransition.ts.html +68 -68
  389. package/coverage/lcov-report/src/transition/useCarousel.ts.html +1 -1
  390. package/coverage/lcov-report/src/transition/useCollapseTransition.ts.html +87 -87
  391. package/coverage/lcov-report/src/transition/useCrossFadeTransition.ts.html +1 -1
  392. package/coverage/lcov-report/src/transition/useMaxWidthTransition.ts.html +1 -1
  393. package/coverage/lcov-report/src/transition/useScaleTransition.ts.html +18 -18
  394. package/coverage/lcov-report/src/transition/useSkeletonPlaceholder.ts.html +607 -562
  395. package/coverage/lcov-report/src/transition/useSlideTransition.ts.html +1 -1
  396. package/coverage/lcov-report/src/transition/useTransition.ts.html +237 -237
  397. package/coverage/lcov-report/src/transition/utils.ts.html +43 -43
  398. package/coverage/lcov-report/src/tree/DefaultTreeItemRenderer.tsx.html +18 -6
  399. package/coverage/lcov-report/src/tree/Tree.tsx.html +20 -8
  400. package/coverage/lcov-report/src/tree/TreeGroup.tsx.html +45 -45
  401. package/coverage/lcov-report/src/tree/TreeItem.tsx.html +7 -10
  402. package/coverage/lcov-report/src/tree/TreeItemExpander.tsx.html +1 -1
  403. package/coverage/lcov-report/src/tree/TreeProvider.tsx.html +8 -8
  404. package/coverage/lcov-report/src/tree/index.html +11 -11
  405. package/coverage/lcov-report/src/tree/styles.ts.html +8 -35
  406. package/coverage/lcov-report/src/tree/useTree.ts.html +1 -1
  407. package/coverage/lcov-report/src/tree/useTreeExpansion.ts.html +1 -1
  408. package/coverage/lcov-report/src/tree/useTreeItems.ts.html +1 -1
  409. package/coverage/lcov-report/src/tree/useTreeMovement.ts.html +1 -1
  410. package/coverage/lcov-report/src/tree/useTreeSelection.ts.html +1 -1
  411. package/coverage/lcov-report/src/tree/utils.ts.html +1 -1
  412. package/coverage/lcov-report/src/typography/SrOnly.tsx.html +1 -1
  413. package/coverage/lcov-report/src/typography/TextContainer.tsx.html +1 -1
  414. package/coverage/lcov-report/src/typography/Typography.tsx.html +1 -1
  415. package/coverage/lcov-report/src/typography/WritingDirectionProvider.tsx.html +1 -1
  416. package/coverage/lcov-report/src/typography/index.html +1 -1
  417. package/coverage/lcov-report/src/useAsyncAction.ts.html +1 -1
  418. package/coverage/lcov-report/src/useDebouncedFunction.ts.html +1 -1
  419. package/coverage/lcov-report/src/useDropzone.ts.html +1 -1
  420. package/coverage/lcov-report/src/useElementSize.ts.html +334 -0
  421. package/coverage/lcov-report/src/useEnsuredId.ts.html +8 -8
  422. package/coverage/lcov-report/src/useEnsuredRef.ts.html +14 -14
  423. package/coverage/lcov-report/src/useEnsuredState.ts.html +1 -1
  424. package/coverage/lcov-report/src/useHtmlClassName.ts.html +1 -1
  425. package/coverage/lcov-report/src/useIntersectionObserver.ts.html +1 -1
  426. package/coverage/lcov-report/src/useIsomorphicLayoutEffect.ts.html +1 -1
  427. package/coverage/lcov-report/src/useLocalStorage.ts.html +1 -1
  428. package/coverage/lcov-report/src/useOrientation.ts.html +32 -32
  429. package/coverage/lcov-report/src/usePageInactive.ts.html +30 -30
  430. package/coverage/lcov-report/src/useResizeListener.ts.html +38 -32
  431. package/coverage/lcov-report/src/useResizeObserver.ts.html +68 -179
  432. package/coverage/lcov-report/src/useThrottledFunction.ts.html +1 -1
  433. package/coverage/lcov-report/src/useToggle.ts.html +1 -1
  434. package/coverage/lcov-report/src/useUnmounted.ts.html +1 -1
  435. package/coverage/lcov-report/src/useWindowSize.ts.html +124 -94
  436. package/coverage/lcov-report/src/utils/RenderRecursively.tsx.html +1 -1
  437. package/coverage/lcov-report/src/utils/alphaNumericSort.ts.html +1 -1
  438. package/coverage/lcov-report/src/utils/applyRef.ts.html +11 -11
  439. package/coverage/lcov-report/src/utils/bem.ts.html +45 -45
  440. package/coverage/lcov-report/src/utils/filters.ts.html +1 -1
  441. package/coverage/lcov-report/src/utils/getClientPosition.ts.html +1 -1
  442. package/coverage/lcov-report/src/utils/getMiddleOfRange.ts.html +163 -0
  443. package/coverage/lcov-report/src/utils/getPercentage.ts.html +9 -9
  444. package/coverage/lcov-report/src/utils/getRangeDefaultValue.ts.html +66 -87
  445. package/coverage/lcov-report/src/utils/getRangeSteps.ts.html +7 -7
  446. package/coverage/lcov-report/src/utils/identity.ts.html +1 -1
  447. package/coverage/lcov-report/src/utils/index.html +46 -31
  448. package/coverage/lcov-report/src/utils/isElementVisible.ts.html +1 -1
  449. package/coverage/lcov-report/src/utils/isValidNumber.ts.html +118 -0
  450. package/coverage/lcov-report/src/utils/loop.ts.html +1 -1
  451. package/coverage/lcov-report/src/utils/nearest.ts.html +21 -21
  452. package/coverage/lcov-report/src/utils/parseCssLengthUnit.ts.html +18 -18
  453. package/coverage/lcov-report/src/utils/randomInt.ts.html +52 -52
  454. package/coverage/lcov-report/src/utils/wait.ts.html +1 -1
  455. package/coverage/lcov-report/src/utils/withinRange.ts.html +1 -1
  456. package/coverage/lcov-report/src/window-splitter/WindowSplitter.tsx.html +1 -1
  457. package/coverage/lcov-report/src/window-splitter/index.html +14 -14
  458. package/coverage/lcov-report/src/window-splitter/useWindowSplitter.ts.html +19 -67
  459. package/coverage/lcov-report/src/window-splitter/useWindowSplitterMaxValue.ts.html +256 -0
  460. package/coverage/lcov-report/suspense/CircularProgressSuspense.tsx.html +283 -0
  461. package/coverage/lcov-report/suspense/NullSuspense.tsx.html +202 -0
  462. package/coverage/lcov-report/suspense/index.html +131 -0
  463. package/coverage/lcov-report/tabIndicatorStyles.ts.html +43 -13
  464. package/coverage/lcov-report/tabListStyles.ts.html +35 -26
  465. package/coverage/lcov-report/tabStyles.ts.html +68 -26
  466. package/coverage/lcov-report/tabs/Tab.tsx.html +233 -143
  467. package/coverage/lcov-report/tabs/TabList.tsx.html +85 -85
  468. package/coverage/lcov-report/tabs/index.html +56 -11
  469. package/coverage/lcov-report/tabs/tabIndicatorStyles.ts.html +187 -0
  470. package/coverage/lcov-report/tabs/tabListStyles.ts.html +241 -0
  471. package/coverage/lcov-report/tabs/tabStyles.ts.html +253 -0
  472. package/coverage/lcov-report/tabs/useTabList.ts.html +736 -0
  473. package/coverage/lcov-report/tabs/useTabs.ts.html +1 -1
  474. package/coverage/lcov-report/tabs/utils.ts.html +1 -1
  475. package/coverage/lcov-report/test-utils/index.html +21 -21
  476. package/coverage/lcov-report/test-utils/use.ts.html +187 -0
  477. package/coverage/lcov-report/tooltip/Tooltip.tsx.html +62 -62
  478. package/coverage/lcov-report/tooltip/index.html +10 -70
  479. package/coverage/lcov-report/tooltip/useTooltip.ts.html +243 -222
  480. package/coverage/lcov-report/transition/SkeletonPlaceholder.tsx.html +595 -0
  481. package/coverage/lcov-report/transition/config.ts.html +5 -5
  482. package/coverage/lcov-report/transition/index.html +1 -1
  483. package/coverage/lcov-report/transition/skeletonPlaceholderUtils.ts.html +400 -0
  484. package/coverage/lcov-report/transition/useSkeletonPlaceholder.ts.html +952 -0
  485. package/coverage/lcov-report/tree/TreeItem.tsx.html +7 -10
  486. package/coverage/lcov-report/tree/index.html +12 -27
  487. package/coverage/lcov-report/tree/styles.ts.html +538 -0
  488. package/coverage/lcov-report/typography/Typography.tsx.html +110 -110
  489. package/coverage/lcov-report/typography/WritingDirectionProvider.tsx.html +75 -75
  490. package/coverage/lcov-report/typography/index.html +15 -15
  491. package/coverage/lcov-report/useSkeletonPlaceholder.ts.html +952 -0
  492. package/coverage/lcov-report/useTabList.ts.html +142 -136
  493. package/coverage/lcov-report/useWindowSplitter.ts.html +640 -0
  494. package/coverage/lcov-report/useWindowSplitterMaxValue.ts.html +256 -0
  495. package/coverage/lcov-report/utils/index.html +16 -31
  496. package/coverage/lcov-report/utils/isElementVisible.ts.html +14 -14
  497. package/coverage/lcov-report/utils/randomInt.ts.html +148 -0
  498. package/coverage/lcov-report/utils/wait.ts.html +1 -1
  499. package/coverage/lcov-report/window-splitter/index.html +21 -36
  500. package/coverage/lcov-report/window-splitter/useWindowSplitter.ts.html +406 -328
  501. package/coverage/lcov.info +580 -0
  502. package/dist/_box-shadows.scss +12 -2
  503. package/dist/_core.scss +1 -3
  504. package/dist/_utils.scss +22 -0
  505. package/dist/app-bar/AppBar.d.ts +4 -9
  506. package/dist/app-bar/_app-bar.scss +7 -9
  507. package/dist/avatar/Avatar.d.ts +1 -1
  508. package/dist/badge/_badge.scss +12 -7
  509. package/dist/button/TooltippedButton.d.ts +62 -0
  510. package/dist/card/ClickableCard.d.ts +42 -0
  511. package/dist/card/_card.scss +15 -9
  512. package/dist/card/styles.d.ts +8 -0
  513. package/dist/dialog/_dialog.scss +28 -15
  514. package/dist/divider/_divider.scss +9 -10
  515. package/dist/draggable/useDraggable.d.ts +12 -23
  516. package/dist/draggable/utils.d.ts +4 -17
  517. package/dist/expansion-panel/_expansion-panel.scss +25 -16
  518. package/dist/expansion-panel/useExpansionPanels.d.ts +5 -3
  519. package/dist/form/MenuItemInputToggle.d.ts +1 -1
  520. package/dist/form/_form.scss +41 -23
  521. package/dist/icon/_icon.scss +7 -2
  522. package/dist/index.d.ts +5 -0
  523. package/dist/interaction/_interaction.scss +12 -9
  524. package/dist/link/_link.scss +26 -12
  525. package/dist/list/ListItem.d.ts +8 -3
  526. package/dist/list/_list.scss +29 -18
  527. package/dist/list/getListItemHeight.d.ts +0 -1
  528. package/dist/list/listItemStyles.d.ts +9 -1
  529. package/dist/list/types.d.ts +15 -5
  530. package/dist/menu/Menu.d.ts +1 -1
  531. package/dist/menu/_menu.scss +3 -16
  532. package/dist/portal/PortalContainerProvider.d.ts +2 -2
  533. package/dist/sheet/styles.d.ts +14 -15
  534. package/dist/src/CoreProviders.js.map +1 -0
  535. package/dist/src/NoSsr.js.map +1 -0
  536. package/dist/src/SsrProvider.js.map +1 -0
  537. package/dist/src/app-bar/AppBar.js +96 -0
  538. package/dist/src/app-bar/AppBar.js.map +1 -0
  539. package/dist/src/app-bar/AppBarTitle.js.map +1 -0
  540. package/dist/src/avatar/Avatar.js.map +1 -0
  541. package/dist/src/avatar/styles.js.map +1 -0
  542. package/dist/src/badge/Badge.js.map +1 -0
  543. package/dist/src/box/Box.js.map +1 -0
  544. package/dist/src/box/styles.js.map +1 -0
  545. package/dist/src/button/AsyncButton.js.map +1 -0
  546. package/dist/src/button/Button.js.map +1 -0
  547. package/dist/src/button/ButtonUnstyled.js.map +1 -0
  548. package/dist/src/button/FloatingActionButton.js.map +1 -0
  549. package/dist/src/button/TooltippedButton.js +62 -0
  550. package/dist/src/button/TooltippedButton.js.map +1 -0
  551. package/dist/src/button/buttonStyles.js.map +1 -0
  552. package/dist/src/button/buttonUnstyledStyles.js.map +1 -0
  553. package/dist/src/card/Card.js +60 -0
  554. package/dist/src/card/Card.js.map +1 -0
  555. package/dist/src/card/CardContent.js +25 -0
  556. package/dist/src/card/CardContent.js.map +1 -0
  557. package/dist/src/card/CardFooter.js.map +1 -0
  558. package/dist/src/card/CardHeader.js.map +1 -0
  559. package/dist/src/card/CardSubtitle.js.map +1 -0
  560. package/dist/src/card/CardTitle.js.map +1 -0
  561. package/dist/src/card/ClickableCard.js +73 -0
  562. package/dist/src/card/ClickableCard.js.map +1 -0
  563. package/dist/src/card/styles.js +65 -0
  564. package/dist/src/card/styles.js.map +1 -0
  565. package/dist/src/chip/Chip.js.map +1 -0
  566. package/dist/src/chip/styles.js.map +1 -0
  567. package/dist/src/cssUtils.js.map +1 -0
  568. package/dist/src/delegateEvent.js.map +1 -0
  569. package/dist/src/dialog/Dialog.js.map +1 -0
  570. package/dist/src/dialog/DialogContainer.js.map +1 -0
  571. package/dist/src/dialog/DialogContent.js.map +1 -0
  572. package/dist/src/dialog/DialogFooter.js.map +1 -0
  573. package/dist/src/dialog/DialogHeader.js.map +1 -0
  574. package/dist/src/dialog/DialogTitle.js.map +1 -0
  575. package/dist/src/dialog/FixedDialog.js.map +1 -0
  576. package/dist/src/dialog/NestedDialogProvider.js.map +1 -0
  577. package/dist/src/dialog/styles.js.map +1 -0
  578. package/dist/src/divider/Divider.js.map +1 -0
  579. package/dist/src/divider/styles.js.map +1 -0
  580. package/dist/src/draggable/useDraggable.js +434 -0
  581. package/dist/src/draggable/useDraggable.js.map +1 -0
  582. package/dist/src/draggable/utils.js +130 -0
  583. package/dist/src/draggable/utils.js.map +1 -0
  584. package/dist/src/expansion-panel/ExpansionList.js.map +1 -0
  585. package/dist/src/expansion-panel/ExpansionPanel.js.map +1 -0
  586. package/dist/src/expansion-panel/ExpansionPanelHeader.js.map +1 -0
  587. package/dist/src/expansion-panel/useExpansionList.js.map +1 -0
  588. package/dist/src/expansion-panel/useExpansionPanels.js +142 -0
  589. package/dist/src/expansion-panel/useExpansionPanels.js.map +1 -0
  590. package/dist/src/focus/useFocusContainer.js.map +1 -0
  591. package/dist/src/focus/utils.js.map +1 -0
  592. package/dist/src/form/Checkbox.js.map +1 -0
  593. package/dist/src/form/Fieldset.js.map +1 -0
  594. package/dist/src/form/FileInput.js.map +1 -0
  595. package/dist/src/form/Form.js.map +1 -0
  596. package/dist/src/form/FormMessage.js.map +1 -0
  597. package/dist/src/form/FormMessageContainer.js.map +1 -0
  598. package/dist/src/form/FormMessageCounter.js.map +1 -0
  599. package/dist/src/form/InputToggle.js.map +1 -0
  600. package/dist/src/form/InputToggleIcon.js.map +1 -0
  601. package/dist/src/form/Label.js.map +1 -0
  602. package/dist/src/form/Legend.js.map +1 -0
  603. package/dist/src/form/MenuItemCheckbox.js.map +1 -0
  604. package/dist/src/form/MenuItemFileInput.js.map +1 -0
  605. package/dist/src/form/MenuItemInputToggle.js.map +1 -0
  606. package/dist/src/form/MenuItemRadio.js.map +1 -0
  607. package/dist/src/form/MenuItemSwitch.js.map +1 -0
  608. package/dist/src/form/MenuItemTextField.js.map +1 -0
  609. package/dist/src/form/NativeSelect.js.map +1 -0
  610. package/dist/src/form/OptGroup.js.map +1 -0
  611. package/dist/src/form/Option.js.map +1 -0
  612. package/dist/src/form/Password.js.map +1 -0
  613. package/dist/src/form/Radio.js.map +1 -0
  614. package/dist/src/form/Select.js +304 -0
  615. package/dist/src/form/Select.js.map +1 -0
  616. package/dist/src/form/SelectValue.js.map +1 -0
  617. package/dist/src/form/Slider.js.map +1 -0
  618. package/dist/src/form/SliderContainer.js.map +1 -0
  619. package/dist/src/form/SliderMark.js.map +1 -0
  620. package/dist/src/form/SliderMarkLabel.js.map +1 -0
  621. package/dist/src/form/SliderThumb.js.map +1 -0
  622. package/dist/src/form/SliderTrack.js.map +1 -0
  623. package/dist/src/form/SliderValueMarks.js.map +1 -0
  624. package/dist/src/form/SliderValueTooltip.js.map +1 -0
  625. package/dist/src/form/Switch.js.map +1 -0
  626. package/dist/src/form/SwitchTrack.js.map +1 -0
  627. package/dist/src/form/TextArea.js.map +1 -0
  628. package/dist/src/form/TextField.js.map +1 -0
  629. package/dist/src/form/TextFieldAddon.js.map +1 -0
  630. package/dist/src/form/TextFieldContainer.js.map +1 -0
  631. package/dist/src/form/TextFieldContainerStyles.js.map +1 -0
  632. package/dist/src/form/fileUtils.js.map +1 -0
  633. package/dist/src/form/formConfig.js.map +1 -0
  634. package/dist/src/form/formMessageStyles.js.map +1 -0
  635. package/dist/src/form/inputToggleStyles.js.map +1 -0
  636. package/dist/src/form/nativeSelectStyles.js.map +1 -0
  637. package/dist/src/form/optionStyles.js.map +1 -0
  638. package/dist/src/form/passwordStyles.js.map +1 -0
  639. package/dist/src/form/selectStyles.js.map +1 -0
  640. package/dist/src/form/selectUtils.js.map +1 -0
  641. package/dist/src/form/sliderUtils.js.map +1 -0
  642. package/dist/src/form/switchStyles.js.map +1 -0
  643. package/dist/src/form/textAreaStyles.js.map +1 -0
  644. package/dist/src/form/textFieldStyles.js.map +1 -0
  645. package/dist/src/form/types.js.map +1 -0
  646. package/dist/src/form/useCheckboxGroup.js.map +1 -0
  647. package/dist/src/form/useFileUpload.js.map +1 -0
  648. package/dist/src/form/useListboxProvider.js.map +1 -0
  649. package/dist/src/form/useNumberField.js.map +1 -0
  650. package/dist/src/form/useRadioGroup.js.map +1 -0
  651. package/dist/src/form/useRangeSlider.js.map +1 -0
  652. package/dist/src/form/useResizingTextArea.js.map +1 -0
  653. package/dist/src/form/useSlider.js.map +1 -0
  654. package/dist/src/form/useTextField.js.map +1 -0
  655. package/dist/src/form/utils.js.map +1 -0
  656. package/dist/src/form/validation.js.map +1 -0
  657. package/dist/src/hoverMode/useHoverMode.js.map +1 -0
  658. package/dist/src/hoverMode/useHoverModeProvider.js.map +1 -0
  659. package/dist/src/icon/FontIcon.js.map +1 -0
  660. package/dist/src/icon/IconRotator.js +31 -0
  661. package/dist/src/icon/IconRotator.js.map +1 -0
  662. package/dist/src/icon/MaterialIcon.js.map +1 -0
  663. package/dist/src/icon/MaterialSymbol.js.map +1 -0
  664. package/dist/src/icon/SVGIcon.js.map +1 -0
  665. package/dist/src/icon/TextIconSpacing.js.map +1 -0
  666. package/dist/src/icon/iconConfig.js.map +1 -0
  667. package/dist/src/icon/material.js.map +1 -0
  668. package/dist/src/icon/materialConfig.js.map +1 -0
  669. package/dist/src/icon/styles.js.map +1 -0
  670. package/dist/src/index.js +329 -0
  671. package/dist/src/index.js.map +1 -0
  672. package/dist/src/interaction/Ripple.js.map +1 -0
  673. package/dist/src/interaction/RippleContainer.js.map +1 -0
  674. package/dist/src/interaction/UserInteractionModeProvider.js.map +1 -0
  675. package/dist/src/interaction/config.js.map +1 -0
  676. package/dist/src/interaction/types.js.map +1 -0
  677. package/dist/src/interaction/useElementInteraction.js.map +1 -0
  678. package/dist/src/interaction/useHigherContrastChildren.js.map +1 -0
  679. package/dist/src/interaction/utils.js.map +1 -0
  680. package/dist/src/layout/LayoutAppBar.js.map +1 -0
  681. package/dist/src/layout/LayoutNav.js.map +1 -0
  682. package/dist/src/layout/LayoutWindowSplitter.js.map +1 -0
  683. package/dist/src/layout/Main.js.map +1 -0
  684. package/dist/src/layout/layoutNavStyles.js.map +1 -0
  685. package/dist/src/layout/layoutWindowSplitterStyles.js.map +1 -0
  686. package/dist/src/layout/mainStyles.js.map +1 -0
  687. package/dist/src/layout/useExpandableLayout.js.map +1 -0
  688. package/dist/src/layout/useHorizontalLayoutTransition.js.map +1 -0
  689. package/dist/src/layout/useLayoutAppBarHeight.js +78 -0
  690. package/dist/src/layout/useLayoutAppBarHeight.js.map +1 -0
  691. package/dist/src/layout/useLayoutTree.js.map +1 -0
  692. package/dist/src/layout/useLayoutWindowSplitter.js.map +1 -0
  693. package/dist/src/layout/useMainTabIndex.js.map +1 -0
  694. package/dist/src/layout/useResizableLayout.js.map +1 -0
  695. package/dist/src/layout/useTemporaryLayout.js.map +1 -0
  696. package/dist/src/link/Link.js.map +1 -0
  697. package/dist/src/link/SkipToMainContent.js.map +1 -0
  698. package/dist/src/link/styles.js.map +1 -0
  699. package/dist/src/list/List.js.map +1 -0
  700. package/dist/src/list/ListItem.js +148 -0
  701. package/dist/src/list/ListItem.js.map +1 -0
  702. package/dist/src/list/ListItemAddon.js +31 -0
  703. package/dist/src/list/ListItemAddon.js.map +1 -0
  704. package/dist/src/list/ListItemChildren.js +82 -0
  705. package/dist/src/list/ListItemChildren.js.map +1 -0
  706. package/dist/src/list/ListItemLink.js +89 -0
  707. package/dist/src/list/ListItemLink.js.map +1 -0
  708. package/dist/src/list/ListItemText.js.map +1 -0
  709. package/dist/src/list/ListSubheader.js.map +1 -0
  710. package/dist/src/list/getListItemHeight.js +28 -0
  711. package/dist/src/list/getListItemHeight.js.map +1 -0
  712. package/dist/src/list/listItemStyles.js +45 -0
  713. package/dist/src/list/listItemStyles.js.map +1 -0
  714. package/dist/src/list/types.js.map +1 -0
  715. package/dist/src/media-queries/AppSizeProvider.js.map +1 -0
  716. package/dist/src/media-queries/appSize.js.map +1 -0
  717. package/dist/src/media-queries/useMediaQuery.js.map +1 -0
  718. package/dist/src/menu/DropdownMenu.js.map +1 -0
  719. package/dist/src/menu/Menu.js.map +1 -0
  720. package/dist/src/menu/MenuBar.js.map +1 -0
  721. package/dist/src/menu/MenuButton.js.map +1 -0
  722. package/dist/src/menu/MenuConfigurationProvider.js.map +1 -0
  723. package/dist/src/menu/MenuItem.js.map +1 -0
  724. package/dist/src/menu/MenuItemButton.js.map +1 -0
  725. package/dist/src/menu/MenuItemGroup.js.map +1 -0
  726. package/dist/src/menu/MenuItemSeparator.js.map +1 -0
  727. package/dist/src/menu/MenuSheet.js.map +1 -0
  728. package/dist/src/menu/MenuVisibilityProvider.js.map +1 -0
  729. package/dist/src/menu/MenuWidget.js.map +1 -0
  730. package/dist/src/menu/MenuWidgetKeyboardProvider.js.map +1 -0
  731. package/dist/src/menu/useContextMenu.js.map +1 -0
  732. package/dist/src/menu/useMenuBarProvider.js.map +1 -0
  733. package/dist/src/menu/utils.js.map +1 -0
  734. package/dist/src/movement/constants.js.map +1 -0
  735. package/dist/src/movement/findMatchIndex.js.map +1 -0
  736. package/dist/src/movement/types.js.map +1 -0
  737. package/dist/src/movement/useKeyboardMovementProvider.js.map +1 -0
  738. package/dist/src/movement/utils.js.map +1 -0
  739. package/dist/src/overlay/Overlay.js.map +1 -0
  740. package/dist/src/overlay/overlayStyles.js.map +1 -0
  741. package/dist/src/portal/Portal.js.map +1 -0
  742. package/dist/src/portal/PortalContainerProvider.js +60 -0
  743. package/dist/src/portal/PortalContainerProvider.js.map +1 -0
  744. package/dist/src/positioning/constants.js.map +1 -0
  745. package/dist/src/positioning/createHorizontalPosition.js.map +1 -0
  746. package/dist/src/positioning/createVerticalPosition.js.map +1 -0
  747. package/dist/src/positioning/getFixedPosition.js.map +1 -0
  748. package/dist/src/positioning/types.js.map +1 -0
  749. package/dist/src/positioning/useFixedPositioning.js.map +1 -0
  750. package/dist/src/positioning/utils.js.map +1 -0
  751. package/dist/src/progress/CircularProgress.js.map +1 -0
  752. package/dist/src/progress/LinearProgress.js.map +1 -0
  753. package/dist/src/progress/getProgressA11y.js.map +1 -0
  754. package/dist/src/progress/types.js.map +1 -0
  755. package/dist/src/responsive-item/ResponsiveItemContainer.js.map +1 -0
  756. package/dist/src/responsive-item/ResponsiveItemOverlay.js.map +1 -0
  757. package/dist/src/responsive-item/styles.js.map +1 -0
  758. package/dist/src/scroll/ScrollLock.js.map +1 -0
  759. package/dist/src/scroll/getScrollbarWidth.js.map +1 -0
  760. package/dist/src/scroll/useScrollLock.js.map +1 -0
  761. package/dist/src/segmented-button/SegmentedButton.js.map +1 -0
  762. package/dist/src/segmented-button/SegmentedButtonContainer.js.map +1 -0
  763. package/dist/src/segmented-button/segmentedButtonContainerStyles.js.map +1 -0
  764. package/dist/src/segmented-button/segmentedButtonStyles.js.map +1 -0
  765. package/dist/src/sheet/Sheet.js.map +1 -0
  766. package/dist/src/sheet/styles.js.map +1 -0
  767. package/dist/src/snackbar/DefaultToastRenderer.js.map +1 -0
  768. package/dist/src/snackbar/Snackbar.js.map +1 -0
  769. package/dist/src/snackbar/Toast.js.map +1 -0
  770. package/dist/src/snackbar/ToastActionButton.js.map +1 -0
  771. package/dist/src/snackbar/ToastCloseButton.js.map +1 -0
  772. package/dist/src/snackbar/ToastContent.js.map +1 -0
  773. package/dist/src/snackbar/ToastManager.js.map +1 -0
  774. package/dist/src/snackbar/ToastManagerProvider.js.map +1 -0
  775. package/dist/src/snackbar/snackbarStyles.js.map +1 -0
  776. package/dist/src/snackbar/toastContentStyles.js.map +1 -0
  777. package/dist/src/snackbar/toastStyles.js.map +1 -0
  778. package/dist/src/snackbar/useCurrentToastActions.js.map +1 -0
  779. package/dist/src/suspense/CircularProgressSuspense.js.map +1 -0
  780. package/dist/src/suspense/NullSuspense.js.map +1 -0
  781. package/dist/src/table/Table.js.map +1 -0
  782. package/dist/src/table/TableBody.js.map +1 -0
  783. package/dist/src/table/TableCell.js.map +1 -0
  784. package/dist/src/table/TableCellContent.js.map +1 -0
  785. package/dist/src/table/TableCheckbox.js +115 -0
  786. package/dist/src/table/TableCheckbox.js.map +1 -0
  787. package/dist/src/table/TableConfigurationProvider.js.map +1 -0
  788. package/dist/src/table/TableContainer.js.map +1 -0
  789. package/dist/src/table/TableContainerProvider.js.map +1 -0
  790. package/dist/src/table/TableFooter.js.map +1 -0
  791. package/dist/src/table/TableHeader.js.map +1 -0
  792. package/dist/src/table/TableRadio.js +108 -0
  793. package/dist/src/table/TableRadio.js.map +1 -0
  794. package/dist/src/table/TableRow.js.map +1 -0
  795. package/dist/src/table/tableCellStyles.js.map +1 -0
  796. package/dist/src/table/tableContainerStyles.js.map +1 -0
  797. package/dist/src/table/tableFooterStyles.js.map +1 -0
  798. package/dist/src/table/tableHeaderStyles.js.map +1 -0
  799. package/dist/src/table/tableRowStyles.js.map +1 -0
  800. package/dist/src/table/tableStyles.js.map +1 -0
  801. package/dist/src/table/types.js.map +1 -0
  802. package/dist/src/tabs/Tab.js +70 -0
  803. package/dist/src/tabs/Tab.js.map +1 -0
  804. package/dist/src/tabs/TabList.js.map +1 -0
  805. package/dist/src/tabs/TabListScrollButton.js.map +1 -0
  806. package/dist/src/tabs/tabIndicatorStyles.js +17 -0
  807. package/dist/src/tabs/tabIndicatorStyles.js.map +1 -0
  808. package/dist/src/tabs/tabListScrollButtonStyles.js.map +1 -0
  809. package/dist/src/tabs/tabListStyles.js +22 -0
  810. package/dist/src/tabs/tabListStyles.js.map +1 -0
  811. package/dist/src/tabs/tabStyles.js +24 -0
  812. package/dist/src/tabs/tabStyles.js.map +1 -0
  813. package/dist/src/tabs/useTabList.js +131 -0
  814. package/dist/src/tabs/useTabList.js.map +1 -0
  815. package/dist/src/tabs/useTabs.js.map +1 -0
  816. package/dist/src/tabs/utils.js.map +1 -0
  817. package/dist/src/test-utils/IntersectionObserver.js.map +1 -0
  818. package/dist/src/test-utils/ResizeObserver.js.map +1 -0
  819. package/dist/src/test-utils/data-testid.js.map +1 -0
  820. package/dist/src/test-utils/index.js.map +1 -0
  821. package/dist/src/test-utils/jest-setup.js.map +1 -0
  822. package/dist/src/test-utils/matchMedia.js.map +1 -0
  823. package/dist/src/test-utils/polyfills/IntersectionObserver.js.map +1 -0
  824. package/dist/src/test-utils/polyfills/ResizeObserver.js.map +1 -0
  825. package/dist/src/test-utils/polyfills/index.js.map +1 -0
  826. package/dist/src/test-utils/polyfills/matchMedia.js.map +1 -0
  827. package/dist/src/test-utils/polyfills/offsetParent.js.map +1 -0
  828. package/dist/src/test-utils/polyfills/scrollIntoView.js.map +1 -0
  829. package/dist/src/test-utils/render.js.map +1 -0
  830. package/dist/src/test-utils/timers.js.map +1 -0
  831. package/dist/src/theme/LocalStorageColorSchemeProvider.js.map +1 -0
  832. package/dist/src/theme/ThemeProvider.js.map +1 -0
  833. package/dist/src/theme/colors.js.map +1 -0
  834. package/dist/src/theme/cssVars.js.map +1 -0
  835. package/dist/src/theme/types.js.map +1 -0
  836. package/dist/src/theme/useCSSVariables.js.map +1 -0
  837. package/dist/src/theme/useColorScheme.js.map +1 -0
  838. package/dist/src/theme/useColorSchemeMetaTag.js.map +1 -0
  839. package/dist/src/theme/useColorSchemeProvider.js.map +1 -0
  840. package/dist/src/theme/usePrefersColorScheme.js.map +1 -0
  841. package/dist/src/theme/utils.js.map +1 -0
  842. package/dist/src/tooltip/Tooltip.js.map +1 -0
  843. package/dist/src/tooltip/TooltipHoverModeProvider.js.map +1 -0
  844. package/dist/src/tooltip/constants.js.map +1 -0
  845. package/dist/src/tooltip/tooltipStyles.js.map +1 -0
  846. package/dist/src/tooltip/useTooltip.js.map +1 -0
  847. package/dist/src/tooltip/useTooltipPosition.js.map +1 -0
  848. package/dist/src/tooltip/utils.js.map +1 -0
  849. package/dist/src/transition/CSSTransition.js.map +1 -0
  850. package/dist/src/transition/Collapse.js.map +1 -0
  851. package/dist/src/transition/CrossFade.js.map +1 -0
  852. package/dist/src/transition/ScaleTransition.js.map +1 -0
  853. package/dist/src/transition/SkeletonPlaceholder.js +131 -0
  854. package/dist/src/transition/SkeletonPlaceholder.js.map +1 -0
  855. package/dist/src/transition/Slide.js.map +1 -0
  856. package/dist/src/transition/SlideContainer.js.map +1 -0
  857. package/dist/src/transition/collapseStyles.js.map +1 -0
  858. package/dist/src/transition/config.js.map +1 -0
  859. package/dist/src/transition/maxWidthTransition.js.map +1 -0
  860. package/dist/src/transition/skeletonPlaceholderUtils.js +38 -0
  861. package/dist/src/transition/skeletonPlaceholderUtils.js.map +1 -0
  862. package/dist/src/transition/types.js.map +1 -0
  863. package/dist/src/transition/useCSSTransition.js.map +1 -0
  864. package/dist/src/transition/useCarousel.js.map +1 -0
  865. package/dist/src/transition/useCollapseTransition.js.map +1 -0
  866. package/dist/src/transition/useCrossFadeTransition.js.map +1 -0
  867. package/dist/src/transition/useMaxWidthTransition.js.map +1 -0
  868. package/dist/src/transition/useScaleTransition.js.map +1 -0
  869. package/dist/src/transition/useSkeletonPlaceholder.js +69 -0
  870. package/dist/src/transition/useSkeletonPlaceholder.js.map +1 -0
  871. package/dist/src/transition/useSlideTransition.js.map +1 -0
  872. package/dist/src/transition/useTransition.js.map +1 -0
  873. package/dist/src/transition/utils.js.map +1 -0
  874. package/dist/src/tree/DefaultTreeItemRenderer.js.map +1 -0
  875. package/dist/src/tree/Tree.js.map +1 -0
  876. package/dist/src/tree/TreeGroup.js.map +1 -0
  877. package/dist/src/tree/TreeItem.js +173 -0
  878. package/dist/src/tree/TreeItem.js.map +1 -0
  879. package/dist/src/tree/TreeItemExpander.js.map +1 -0
  880. package/dist/src/tree/TreeProvider.js.map +1 -0
  881. package/dist/src/tree/styles.js +58 -0
  882. package/dist/src/tree/styles.js.map +1 -0
  883. package/dist/src/tree/types.js.map +1 -0
  884. package/dist/src/tree/useTree.js.map +1 -0
  885. package/dist/src/tree/useTreeExpansion.js.map +1 -0
  886. package/dist/src/tree/useTreeItems.js.map +1 -0
  887. package/dist/src/tree/useTreeMovement.js.map +1 -0
  888. package/dist/src/tree/useTreeSelection.js.map +1 -0
  889. package/dist/src/tree/utils.js.map +1 -0
  890. package/dist/src/types.js +5 -0
  891. package/dist/src/types.js.map +1 -0
  892. package/dist/src/typography/SrOnly.js.map +1 -0
  893. package/dist/src/typography/TextContainer.js.map +1 -0
  894. package/dist/src/typography/Typography.js.map +1 -0
  895. package/dist/src/typography/WritingDirectionProvider.js.map +1 -0
  896. package/dist/src/useAsyncAction.js.map +1 -0
  897. package/dist/src/useDebouncedFunction.js.map +1 -0
  898. package/dist/src/useDropzone.js.map +1 -0
  899. package/dist/src/useElementSize.js +53 -0
  900. package/dist/src/useElementSize.js.map +1 -0
  901. package/dist/src/useEnsuredId.js.map +1 -0
  902. package/dist/src/useEnsuredRef.js.map +1 -0
  903. package/dist/src/useEnsuredState.js.map +1 -0
  904. package/dist/src/useHtmlClassName.js.map +1 -0
  905. package/dist/src/useIntersectionObserver.js.map +1 -0
  906. package/dist/src/useIsomorphicLayoutEffect.js.map +1 -0
  907. package/dist/src/useLocalStorage.js.map +1 -0
  908. package/dist/src/useOrientation.js.map +1 -0
  909. package/dist/src/usePageInactive.js.map +1 -0
  910. package/dist/src/useResizeListener.js +71 -0
  911. package/dist/src/useResizeListener.js.map +1 -0
  912. package/dist/src/useResizeObserver.js +134 -0
  913. package/dist/src/useResizeObserver.js.map +1 -0
  914. package/dist/src/useThrottledFunction.js.map +1 -0
  915. package/dist/src/useToggle.js.map +1 -0
  916. package/dist/src/useUnmounted.js.map +1 -0
  917. package/dist/src/useWindowSize.js +68 -0
  918. package/dist/src/useWindowSize.js.map +1 -0
  919. package/dist/src/utils/RenderRecursively.js.map +1 -0
  920. package/dist/src/utils/alphaNumericSort.js.map +1 -0
  921. package/dist/src/utils/applyRef.js.map +1 -0
  922. package/dist/src/utils/bem.js.map +1 -0
  923. package/dist/src/utils/filters.js.map +1 -0
  924. package/dist/src/utils/getClientPosition.js.map +1 -0
  925. package/dist/src/utils/getMiddleOfRange.js +20 -0
  926. package/dist/src/utils/getMiddleOfRange.js.map +1 -0
  927. package/dist/src/utils/getPercentage.js.map +1 -0
  928. package/dist/src/utils/getRangeDefaultValue.js +13 -0
  929. package/dist/src/utils/getRangeDefaultValue.js.map +1 -0
  930. package/dist/src/utils/getRangeSteps.js +17 -0
  931. package/dist/src/utils/getRangeSteps.js.map +1 -0
  932. package/dist/src/utils/identity.js.map +1 -0
  933. package/dist/src/utils/isElementVisible.js.map +1 -0
  934. package/dist/src/utils/loop.js.map +1 -0
  935. package/dist/src/utils/nearest.js +27 -0
  936. package/dist/src/utils/nearest.js.map +1 -0
  937. package/dist/src/utils/parseCssLengthUnit.js.map +1 -0
  938. package/dist/src/utils/randomInt.js.map +1 -0
  939. package/dist/src/utils/wait.js.map +1 -0
  940. package/dist/src/utils/withinRange.js.map +1 -0
  941. package/dist/src/window-splitter/WindowSplitter.js.map +1 -0
  942. package/dist/src/window-splitter/useWindowSplitter.js +59 -0
  943. package/dist/src/window-splitter/useWindowSplitter.js.map +1 -0
  944. package/dist/table/TableCheckbox.d.ts +3 -2
  945. package/dist/table/TableRadio.d.ts +3 -2
  946. package/dist/table/tableCellStyles.d.ts +1 -1
  947. package/dist/tabs/Tab.d.ts +24 -3
  948. package/dist/tabs/_tabs.scss +28 -16
  949. package/dist/tabs/tabIndicatorStyles.d.ts +2 -1
  950. package/dist/tabs/tabStyles.d.ts +2 -0
  951. package/dist/tabs/useTabList.d.ts +3 -3
  952. package/dist/theme/_theme.scss +20 -10
  953. package/dist/tooltip/useTooltip.d.ts +14 -14
  954. package/dist/transition/SkeletonPlaceholder.d.ts +2 -2
  955. package/dist/transition/_transition.scss +12 -7
  956. package/dist/transition/skeletonPlaceholderUtils.d.ts +77 -0
  957. package/dist/transition/useSkeletonPlaceholder.d.ts +12 -7
  958. package/dist/tree/DefaultTreeItemRenderer.d.ts +2 -2
  959. package/dist/tree/Tree.d.ts +8 -4
  960. package/dist/tree/_tree.scss +29 -22
  961. package/dist/tree/styles.d.ts +0 -6
  962. package/dist/types.d.ts +7 -0
  963. package/dist/typography/_typography.scss +12 -2
  964. package/dist/useElementSize.d.ts +40 -0
  965. package/dist/useResizeListener.d.ts +1 -1
  966. package/dist/useResizeObserver.d.ts +4 -43
  967. package/dist/useWindowSize.d.ts +14 -11
  968. package/dist/utils/getMiddleOfRange.d.ts +13 -0
  969. package/dist/utils/getRangeDefaultValue.d.ts +3 -5
  970. package/dist/utils/getRangeSteps.d.ts +1 -1
  971. package/dist/window-splitter/_window-splitter.scss +11 -16
  972. package/dist/window-splitter/useWindowSplitter.d.ts +3 -5
  973. package/package.json +19 -19
  974. package/src/__tests__/useElementSize.tsx +181 -0
  975. package/src/__tests__/useWindowSize.node.tsx +56 -0
  976. package/src/__tests__/useWindowSize.tsx +156 -0
  977. package/src/_box-shadows.scss +12 -2
  978. package/src/_core.scss +1 -3
  979. package/src/_utils.scss +22 -0
  980. package/src/app-bar/AppBar.tsx +59 -19
  981. package/src/app-bar/__tests__/__snapshots__/AppBar.tsx.snap +21 -21
  982. package/src/app-bar/_app-bar.scss +7 -9
  983. package/src/avatar/Avatar.tsx +1 -1
  984. package/src/badge/_badge.scss +12 -7
  985. package/src/button/TooltippedButton.tsx +120 -0
  986. package/src/button/__tests__/TooltippedButton.tsx +60 -0
  987. package/src/button/__tests__/__snapshots__/TooltippedButton.tsx.snap +26 -0
  988. package/src/card/Card.tsx +5 -3
  989. package/src/card/CardContent.tsx +3 -3
  990. package/src/card/ClickableCard.tsx +105 -0
  991. package/src/card/__tests__/ClickableCard.tsx +66 -0
  992. package/src/card/__tests__/__snapshots__/CardHeader.tsx.snap +1 -1
  993. package/src/card/__tests__/__snapshots__/CardSubtitle.tsx.snap +2 -2
  994. package/src/card/__tests__/__snapshots__/ClickableCard.tsx.snap +20 -0
  995. package/src/card/__tests__/__snapshots__/styles.ts.snap +1 -1
  996. package/src/card/_card.scss +15 -9
  997. package/src/card/styles.ts +19 -10
  998. package/src/dialog/_dialog.scss +28 -15
  999. package/src/divider/_divider.scss +9 -10
  1000. package/src/draggable/useDraggable.ts +26 -25
  1001. package/src/draggable/utils.ts +16 -50
  1002. package/src/expansion-panel/__tests__/ExpansionPanel.tsx +2 -2
  1003. package/src/expansion-panel/_expansion-panel.scss +25 -16
  1004. package/src/expansion-panel/useExpansionPanels.ts +20 -16
  1005. package/src/form/MenuItemInputToggle.tsx +1 -1
  1006. package/src/form/Select.tsx +9 -1
  1007. package/src/form/_form.scss +41 -23
  1008. package/src/icon/IconRotator.tsx +1 -2
  1009. package/src/icon/_icon.scss +7 -2
  1010. package/src/index.ts +5 -0
  1011. package/src/interaction/_interaction.scss +12 -9
  1012. package/src/layout/__tests__/__snapshots__/LayoutAppBar.tsx.snap +4 -4
  1013. package/src/layout/__tests__/__snapshots__/useExpandableLayout.tsx.snap +1 -1
  1014. package/src/layout/__tests__/__snapshots__/useLayoutTree.tsx.snap +18 -18
  1015. package/src/layout/__tests__/__snapshots__/useResizableLayout.tsx.snap +1 -1
  1016. package/src/layout/__tests__/__snapshots__/useTemporaryLayout.tsx.snap +1 -1
  1017. package/src/layout/useLayoutAppBarHeight.ts +5 -9
  1018. package/src/link/_link.scss +26 -12
  1019. package/src/list/ListItem.tsx +20 -13
  1020. package/src/list/ListItemAddon.tsx +5 -3
  1021. package/src/list/ListItemChildren.tsx +4 -2
  1022. package/src/list/ListItemLink.tsx +4 -4
  1023. package/src/list/__tests__/ListItem.tsx +1 -1
  1024. package/src/list/__tests__/__snapshots__/ListItem.tsx.snap +1 -1
  1025. package/src/list/__tests__/getListItemHeight.ts +2 -2
  1026. package/src/list/_list.scss +29 -18
  1027. package/src/list/getListItemHeight.ts +2 -3
  1028. package/src/list/listItemStyles.ts +15 -5
  1029. package/src/list/types.ts +16 -5
  1030. package/src/menu/Menu.tsx +1 -1
  1031. package/src/menu/_menu.scss +3 -16
  1032. package/src/portal/PortalContainerProvider.tsx +10 -2
  1033. package/src/portal/__tests__/PortalContainerProvider.tsx +23 -0
  1034. package/src/sheet/styles.ts +14 -15
  1035. package/src/suspense/__tests__/CircularProgressSuspense.tsx +90 -0
  1036. package/src/suspense/__tests__/NullSuspense.tsx +46 -0
  1037. package/src/suspense/__tests__/__snapshots__/CircularProgressSuspense.tsx.snap +24 -0
  1038. package/src/table/TableCheckbox.tsx +4 -2
  1039. package/src/table/TableRadio.tsx +4 -2
  1040. package/src/table/tableCellStyles.ts +1 -1
  1041. package/src/tabs/Tab.tsx +110 -70
  1042. package/src/tabs/__tests__/Tab.tsx +25 -2
  1043. package/src/tabs/__tests__/TabList.tsx +4 -4
  1044. package/src/tabs/__tests__/__snapshots__/TabList.tsx.snap +2 -2
  1045. package/src/tabs/_tabs.scss +28 -16
  1046. package/src/tabs/tabIndicatorStyles.ts +13 -3
  1047. package/src/tabs/tabListStyles.ts +1 -1
  1048. package/src/tabs/tabStyles.ts +16 -4
  1049. package/src/tabs/useTabList.ts +10 -8
  1050. package/src/theme/_theme.scss +20 -10
  1051. package/src/tooltip/useTooltip.ts +23 -16
  1052. package/src/transition/SkeletonPlaceholder.tsx +18 -6
  1053. package/src/transition/__tests__/SkeletonPlaceholder.tsx +72 -0
  1054. package/src/transition/__tests__/__snapshots__/SkeletonPlaceholder.tsx.snap +24 -0
  1055. package/src/transition/_transition.scss +12 -7
  1056. package/src/transition/skeletonPlaceholderUtils.ts +105 -0
  1057. package/src/transition/useSkeletonPlaceholder.ts +62 -47
  1058. package/src/tree/DefaultTreeItemRenderer.tsx +6 -2
  1059. package/src/tree/Tree.tsx +8 -4
  1060. package/src/tree/TreeItem.tsx +3 -4
  1061. package/src/tree/__tests__/Tree.tsx +1 -1
  1062. package/src/tree/__tests__/__snapshots__/Tree.tsx.snap +124 -124
  1063. package/src/tree/_tree.scss +29 -22
  1064. package/src/tree/styles.ts +0 -9
  1065. package/src/types.ts +8 -0
  1066. package/src/typography/_typography.scss +12 -2
  1067. package/src/useElementSize.ts +83 -0
  1068. package/src/useResizeListener.ts +3 -1
  1069. package/src/useResizeObserver.ts +7 -44
  1070. package/src/useWindowSize.ts +29 -19
  1071. package/src/utils/__tests__/getMiddleOfRange.ts +12 -0
  1072. package/src/utils/__tests__/getRangeDefaultValue.ts +47 -0
  1073. package/src/utils/getMiddleOfRange.ts +26 -0
  1074. package/src/utils/getRangeDefaultValue.ts +8 -15
  1075. package/src/utils/getRangeSteps.ts +2 -2
  1076. package/src/utils/nearest.ts +1 -1
  1077. package/src/window-splitter/_window-splitter.scss +11 -16
  1078. package/src/window-splitter/useWindowSplitter.ts +12 -28
  1079. package/dist/CoreProviders.js.map +0 -1
  1080. package/dist/NoSsr.js.map +0 -1
  1081. package/dist/SsrProvider.js.map +0 -1
  1082. package/dist/app-bar/AppBar.js +0 -74
  1083. package/dist/app-bar/AppBar.js.map +0 -1
  1084. package/dist/app-bar/AppBarTitle.js.map +0 -1
  1085. package/dist/avatar/Avatar.js.map +0 -1
  1086. package/dist/avatar/styles.js.map +0 -1
  1087. package/dist/badge/Badge.js.map +0 -1
  1088. package/dist/box/Box.js.map +0 -1
  1089. package/dist/box/styles.js.map +0 -1
  1090. package/dist/button/AsyncButton.js.map +0 -1
  1091. package/dist/button/Button.js.map +0 -1
  1092. package/dist/button/ButtonUnstyled.js.map +0 -1
  1093. package/dist/button/FloatingActionButton.js.map +0 -1
  1094. package/dist/button/buttonStyles.js.map +0 -1
  1095. package/dist/button/buttonUnstyledStyles.js.map +0 -1
  1096. package/dist/card/Card.js +0 -59
  1097. package/dist/card/Card.js.map +0 -1
  1098. package/dist/card/CardContent.js +0 -25
  1099. package/dist/card/CardContent.js.map +0 -1
  1100. package/dist/card/CardFooter.js.map +0 -1
  1101. package/dist/card/CardHeader.js.map +0 -1
  1102. package/dist/card/CardSubtitle.js.map +0 -1
  1103. package/dist/card/CardTitle.js.map +0 -1
  1104. package/dist/card/styles.js +0 -62
  1105. package/dist/card/styles.js.map +0 -1
  1106. package/dist/chip/Chip.js.map +0 -1
  1107. package/dist/chip/styles.js.map +0 -1
  1108. package/dist/cssUtils.js.map +0 -1
  1109. package/dist/delegateEvent.js.map +0 -1
  1110. package/dist/dialog/Dialog.js.map +0 -1
  1111. package/dist/dialog/DialogContainer.js.map +0 -1
  1112. package/dist/dialog/DialogContent.js.map +0 -1
  1113. package/dist/dialog/DialogFooter.js.map +0 -1
  1114. package/dist/dialog/DialogHeader.js.map +0 -1
  1115. package/dist/dialog/DialogTitle.js.map +0 -1
  1116. package/dist/dialog/FixedDialog.js.map +0 -1
  1117. package/dist/dialog/NestedDialogProvider.js.map +0 -1
  1118. package/dist/dialog/styles.js.map +0 -1
  1119. package/dist/divider/Divider.js.map +0 -1
  1120. package/dist/divider/styles.js.map +0 -1
  1121. package/dist/draggable/useDraggable.js +0 -425
  1122. package/dist/draggable/useDraggable.js.map +0 -1
  1123. package/dist/draggable/utils.js +0 -146
  1124. package/dist/draggable/utils.js.map +0 -1
  1125. package/dist/expansion-panel/ExpansionList.js.map +0 -1
  1126. package/dist/expansion-panel/ExpansionPanel.js.map +0 -1
  1127. package/dist/expansion-panel/ExpansionPanelHeader.js.map +0 -1
  1128. package/dist/expansion-panel/useExpansionList.js.map +0 -1
  1129. package/dist/expansion-panel/useExpansionPanels.js +0 -135
  1130. package/dist/expansion-panel/useExpansionPanels.js.map +0 -1
  1131. package/dist/focus/useFocusContainer.js.map +0 -1
  1132. package/dist/focus/utils.js.map +0 -1
  1133. package/dist/form/Checkbox.js.map +0 -1
  1134. package/dist/form/Fieldset.js.map +0 -1
  1135. package/dist/form/FileInput.js.map +0 -1
  1136. package/dist/form/Form.js.map +0 -1
  1137. package/dist/form/FormMessage.js.map +0 -1
  1138. package/dist/form/FormMessageContainer.js.map +0 -1
  1139. package/dist/form/FormMessageCounter.js.map +0 -1
  1140. package/dist/form/InputToggle.js.map +0 -1
  1141. package/dist/form/InputToggleIcon.js.map +0 -1
  1142. package/dist/form/Label.js.map +0 -1
  1143. package/dist/form/Legend.js.map +0 -1
  1144. package/dist/form/MenuItemCheckbox.js.map +0 -1
  1145. package/dist/form/MenuItemFileInput.js.map +0 -1
  1146. package/dist/form/MenuItemInputToggle.js.map +0 -1
  1147. package/dist/form/MenuItemRadio.js.map +0 -1
  1148. package/dist/form/MenuItemSwitch.js.map +0 -1
  1149. package/dist/form/MenuItemTextField.js.map +0 -1
  1150. package/dist/form/NativeSelect.js.map +0 -1
  1151. package/dist/form/OptGroup.js.map +0 -1
  1152. package/dist/form/Option.js.map +0 -1
  1153. package/dist/form/Password.js.map +0 -1
  1154. package/dist/form/Radio.js.map +0 -1
  1155. package/dist/form/Select.js +0 -299
  1156. package/dist/form/Select.js.map +0 -1
  1157. package/dist/form/SelectValue.js.map +0 -1
  1158. package/dist/form/Slider.js.map +0 -1
  1159. package/dist/form/SliderContainer.js.map +0 -1
  1160. package/dist/form/SliderMark.js.map +0 -1
  1161. package/dist/form/SliderMarkLabel.js.map +0 -1
  1162. package/dist/form/SliderThumb.js.map +0 -1
  1163. package/dist/form/SliderTrack.js.map +0 -1
  1164. package/dist/form/SliderValueMarks.js.map +0 -1
  1165. package/dist/form/SliderValueTooltip.js.map +0 -1
  1166. package/dist/form/Switch.js.map +0 -1
  1167. package/dist/form/SwitchTrack.js.map +0 -1
  1168. package/dist/form/TextArea.js.map +0 -1
  1169. package/dist/form/TextField.js.map +0 -1
  1170. package/dist/form/TextFieldAddon.js.map +0 -1
  1171. package/dist/form/TextFieldContainer.js.map +0 -1
  1172. package/dist/form/TextFieldContainerStyles.js.map +0 -1
  1173. package/dist/form/fileUtils.js.map +0 -1
  1174. package/dist/form/formConfig.js.map +0 -1
  1175. package/dist/form/formMessageStyles.js.map +0 -1
  1176. package/dist/form/inputToggleStyles.js.map +0 -1
  1177. package/dist/form/nativeSelectStyles.js.map +0 -1
  1178. package/dist/form/optionStyles.js.map +0 -1
  1179. package/dist/form/passwordStyles.js.map +0 -1
  1180. package/dist/form/selectStyles.js.map +0 -1
  1181. package/dist/form/selectUtils.js.map +0 -1
  1182. package/dist/form/sliderUtils.js.map +0 -1
  1183. package/dist/form/switchStyles.js.map +0 -1
  1184. package/dist/form/textAreaStyles.js.map +0 -1
  1185. package/dist/form/textFieldStyles.js.map +0 -1
  1186. package/dist/form/types.js.map +0 -1
  1187. package/dist/form/useCheckboxGroup.js.map +0 -1
  1188. package/dist/form/useFileUpload.js.map +0 -1
  1189. package/dist/form/useListboxProvider.js.map +0 -1
  1190. package/dist/form/useNumberField.js.map +0 -1
  1191. package/dist/form/useRadioGroup.js.map +0 -1
  1192. package/dist/form/useRangeSlider.js.map +0 -1
  1193. package/dist/form/useResizingTextArea.js.map +0 -1
  1194. package/dist/form/useSlider.js.map +0 -1
  1195. package/dist/form/useTextField.js.map +0 -1
  1196. package/dist/form/utils.js.map +0 -1
  1197. package/dist/form/validation.js.map +0 -1
  1198. package/dist/hoverMode/useHoverMode.js.map +0 -1
  1199. package/dist/hoverMode/useHoverModeProvider.js.map +0 -1
  1200. package/dist/icon/FontIcon.js.map +0 -1
  1201. package/dist/icon/IconRotator.js +0 -32
  1202. package/dist/icon/IconRotator.js.map +0 -1
  1203. package/dist/icon/MaterialIcon.js.map +0 -1
  1204. package/dist/icon/MaterialSymbol.js.map +0 -1
  1205. package/dist/icon/SVGIcon.js.map +0 -1
  1206. package/dist/icon/TextIconSpacing.js.map +0 -1
  1207. package/dist/icon/iconConfig.js.map +0 -1
  1208. package/dist/icon/material.js.map +0 -1
  1209. package/dist/icon/materialConfig.js.map +0 -1
  1210. package/dist/icon/styles.js.map +0 -1
  1211. package/dist/index.js +0 -324
  1212. package/dist/index.js.map +0 -1
  1213. package/dist/interaction/Ripple.js.map +0 -1
  1214. package/dist/interaction/RippleContainer.js.map +0 -1
  1215. package/dist/interaction/UserInteractionModeProvider.js.map +0 -1
  1216. package/dist/interaction/config.js.map +0 -1
  1217. package/dist/interaction/types.js.map +0 -1
  1218. package/dist/interaction/useElementInteraction.js.map +0 -1
  1219. package/dist/interaction/useHigherContrastChildren.js.map +0 -1
  1220. package/dist/interaction/utils.js.map +0 -1
  1221. package/dist/layout/LayoutAppBar.js.map +0 -1
  1222. package/dist/layout/LayoutNav.js.map +0 -1
  1223. package/dist/layout/LayoutWindowSplitter.js.map +0 -1
  1224. package/dist/layout/Main.js.map +0 -1
  1225. package/dist/layout/layoutNavStyles.js.map +0 -1
  1226. package/dist/layout/layoutWindowSplitterStyles.js.map +0 -1
  1227. package/dist/layout/mainStyles.js.map +0 -1
  1228. package/dist/layout/useExpandableLayout.js.map +0 -1
  1229. package/dist/layout/useHorizontalLayoutTransition.js.map +0 -1
  1230. package/dist/layout/useLayoutAppBarHeight.js +0 -82
  1231. package/dist/layout/useLayoutAppBarHeight.js.map +0 -1
  1232. package/dist/layout/useLayoutTree.js.map +0 -1
  1233. package/dist/layout/useLayoutWindowSplitter.js.map +0 -1
  1234. package/dist/layout/useMainTabIndex.js.map +0 -1
  1235. package/dist/layout/useResizableLayout.js.map +0 -1
  1236. package/dist/layout/useTemporaryLayout.js.map +0 -1
  1237. package/dist/link/Link.js.map +0 -1
  1238. package/dist/link/SkipToMainContent.js.map +0 -1
  1239. package/dist/link/styles.js.map +0 -1
  1240. package/dist/list/List.js.map +0 -1
  1241. package/dist/list/ListItem.js +0 -147
  1242. package/dist/list/ListItem.js.map +0 -1
  1243. package/dist/list/ListItemAddon.js +0 -30
  1244. package/dist/list/ListItemAddon.js.map +0 -1
  1245. package/dist/list/ListItemChildren.js +0 -81
  1246. package/dist/list/ListItemChildren.js.map +0 -1
  1247. package/dist/list/ListItemLink.js +0 -89
  1248. package/dist/list/ListItemLink.js.map +0 -1
  1249. package/dist/list/ListItemText.js.map +0 -1
  1250. package/dist/list/ListSubheader.js.map +0 -1
  1251. package/dist/list/getListItemHeight.js +0 -28
  1252. package/dist/list/getListItemHeight.js.map +0 -1
  1253. package/dist/list/listItemStyles.js +0 -45
  1254. package/dist/list/listItemStyles.js.map +0 -1
  1255. package/dist/list/types.js.map +0 -1
  1256. package/dist/media-queries/AppSizeProvider.js.map +0 -1
  1257. package/dist/media-queries/appSize.js.map +0 -1
  1258. package/dist/media-queries/useMediaQuery.js.map +0 -1
  1259. package/dist/menu/DropdownMenu.js.map +0 -1
  1260. package/dist/menu/Menu.js.map +0 -1
  1261. package/dist/menu/MenuBar.js.map +0 -1
  1262. package/dist/menu/MenuButton.js.map +0 -1
  1263. package/dist/menu/MenuConfigurationProvider.js.map +0 -1
  1264. package/dist/menu/MenuItem.js.map +0 -1
  1265. package/dist/menu/MenuItemButton.js.map +0 -1
  1266. package/dist/menu/MenuItemGroup.js.map +0 -1
  1267. package/dist/menu/MenuItemSeparator.js.map +0 -1
  1268. package/dist/menu/MenuSheet.js.map +0 -1
  1269. package/dist/menu/MenuVisibilityProvider.js.map +0 -1
  1270. package/dist/menu/MenuWidget.js.map +0 -1
  1271. package/dist/menu/MenuWidgetKeyboardProvider.js.map +0 -1
  1272. package/dist/menu/useContextMenu.js.map +0 -1
  1273. package/dist/menu/useMenuBarProvider.js.map +0 -1
  1274. package/dist/menu/utils.js.map +0 -1
  1275. package/dist/movement/constants.js.map +0 -1
  1276. package/dist/movement/findMatchIndex.js.map +0 -1
  1277. package/dist/movement/types.js.map +0 -1
  1278. package/dist/movement/useKeyboardMovementProvider.js.map +0 -1
  1279. package/dist/movement/utils.js.map +0 -1
  1280. package/dist/overlay/Overlay.js.map +0 -1
  1281. package/dist/overlay/overlayStyles.js.map +0 -1
  1282. package/dist/portal/Portal.js.map +0 -1
  1283. package/dist/portal/PortalContainerProvider.js +0 -55
  1284. package/dist/portal/PortalContainerProvider.js.map +0 -1
  1285. package/dist/positioning/constants.js.map +0 -1
  1286. package/dist/positioning/createHorizontalPosition.js.map +0 -1
  1287. package/dist/positioning/createVerticalPosition.js.map +0 -1
  1288. package/dist/positioning/getFixedPosition.js.map +0 -1
  1289. package/dist/positioning/types.js.map +0 -1
  1290. package/dist/positioning/useFixedPositioning.js.map +0 -1
  1291. package/dist/positioning/utils.js.map +0 -1
  1292. package/dist/progress/CircularProgress.js.map +0 -1
  1293. package/dist/progress/LinearProgress.js.map +0 -1
  1294. package/dist/progress/getProgressA11y.js.map +0 -1
  1295. package/dist/progress/types.js.map +0 -1
  1296. package/dist/responsive-item/ResponsiveItemContainer.js.map +0 -1
  1297. package/dist/responsive-item/ResponsiveItemOverlay.js.map +0 -1
  1298. package/dist/responsive-item/styles.js.map +0 -1
  1299. package/dist/scroll/ScrollLock.js.map +0 -1
  1300. package/dist/scroll/getScrollbarWidth.js.map +0 -1
  1301. package/dist/scroll/useScrollLock.js.map +0 -1
  1302. package/dist/segmented-button/SegmentedButton.js.map +0 -1
  1303. package/dist/segmented-button/SegmentedButtonContainer.js.map +0 -1
  1304. package/dist/segmented-button/segmentedButtonContainerStyles.js.map +0 -1
  1305. package/dist/segmented-button/segmentedButtonStyles.js.map +0 -1
  1306. package/dist/sheet/Sheet.js.map +0 -1
  1307. package/dist/sheet/styles.js.map +0 -1
  1308. package/dist/snackbar/DefaultToastRenderer.js.map +0 -1
  1309. package/dist/snackbar/Snackbar.js.map +0 -1
  1310. package/dist/snackbar/Toast.js.map +0 -1
  1311. package/dist/snackbar/ToastActionButton.js.map +0 -1
  1312. package/dist/snackbar/ToastCloseButton.js.map +0 -1
  1313. package/dist/snackbar/ToastContent.js.map +0 -1
  1314. package/dist/snackbar/ToastManager.js.map +0 -1
  1315. package/dist/snackbar/ToastManagerProvider.js.map +0 -1
  1316. package/dist/snackbar/snackbarStyles.js.map +0 -1
  1317. package/dist/snackbar/toastContentStyles.js.map +0 -1
  1318. package/dist/snackbar/toastStyles.js.map +0 -1
  1319. package/dist/snackbar/useCurrentToastActions.js.map +0 -1
  1320. package/dist/suspense/CircularProgressSuspense.js.map +0 -1
  1321. package/dist/suspense/NullSuspense.js.map +0 -1
  1322. package/dist/table/Table.js.map +0 -1
  1323. package/dist/table/TableBody.js.map +0 -1
  1324. package/dist/table/TableCell.js.map +0 -1
  1325. package/dist/table/TableCellContent.js.map +0 -1
  1326. package/dist/table/TableCheckbox.js +0 -113
  1327. package/dist/table/TableCheckbox.js.map +0 -1
  1328. package/dist/table/TableConfigurationProvider.js.map +0 -1
  1329. package/dist/table/TableContainer.js.map +0 -1
  1330. package/dist/table/TableContainerProvider.js.map +0 -1
  1331. package/dist/table/TableFooter.js.map +0 -1
  1332. package/dist/table/TableHeader.js.map +0 -1
  1333. package/dist/table/TableRadio.js +0 -106
  1334. package/dist/table/TableRadio.js.map +0 -1
  1335. package/dist/table/TableRow.js.map +0 -1
  1336. package/dist/table/tableCellStyles.js.map +0 -1
  1337. package/dist/table/tableContainerStyles.js.map +0 -1
  1338. package/dist/table/tableFooterStyles.js.map +0 -1
  1339. package/dist/table/tableHeaderStyles.js.map +0 -1
  1340. package/dist/table/tableRowStyles.js.map +0 -1
  1341. package/dist/table/tableStyles.js.map +0 -1
  1342. package/dist/table/types.js.map +0 -1
  1343. package/dist/tabs/Tab.js +0 -63
  1344. package/dist/tabs/Tab.js.map +0 -1
  1345. package/dist/tabs/TabList.js.map +0 -1
  1346. package/dist/tabs/TabListScrollButton.js.map +0 -1
  1347. package/dist/tabs/tabIndicatorStyles.js +0 -14
  1348. package/dist/tabs/tabIndicatorStyles.js.map +0 -1
  1349. package/dist/tabs/tabListScrollButtonStyles.js.map +0 -1
  1350. package/dist/tabs/tabListStyles.js +0 -21
  1351. package/dist/tabs/tabListStyles.js.map +0 -1
  1352. package/dist/tabs/tabStyles.js +0 -21
  1353. package/dist/tabs/tabStyles.js.map +0 -1
  1354. package/dist/tabs/useTabList.js +0 -128
  1355. package/dist/tabs/useTabList.js.map +0 -1
  1356. package/dist/tabs/useTabs.js.map +0 -1
  1357. package/dist/tabs/utils.js.map +0 -1
  1358. package/dist/test-utils/IntersectionObserver.js.map +0 -1
  1359. package/dist/test-utils/ResizeObserver.js.map +0 -1
  1360. package/dist/test-utils/data-testid.js.map +0 -1
  1361. package/dist/test-utils/index.js.map +0 -1
  1362. package/dist/test-utils/jest-setup.js.map +0 -1
  1363. package/dist/test-utils/matchMedia.js.map +0 -1
  1364. package/dist/test-utils/polyfills/IntersectionObserver.js.map +0 -1
  1365. package/dist/test-utils/polyfills/ResizeObserver.js.map +0 -1
  1366. package/dist/test-utils/polyfills/index.js.map +0 -1
  1367. package/dist/test-utils/polyfills/matchMedia.js.map +0 -1
  1368. package/dist/test-utils/polyfills/offsetParent.js.map +0 -1
  1369. package/dist/test-utils/polyfills/scrollIntoView.js.map +0 -1
  1370. package/dist/test-utils/render.js.map +0 -1
  1371. package/dist/test-utils/timers.js.map +0 -1
  1372. package/dist/theme/LocalStorageColorSchemeProvider.js.map +0 -1
  1373. package/dist/theme/ThemeProvider.js.map +0 -1
  1374. package/dist/theme/colors.js.map +0 -1
  1375. package/dist/theme/cssVars.js.map +0 -1
  1376. package/dist/theme/types.js.map +0 -1
  1377. package/dist/theme/useCSSVariables.js.map +0 -1
  1378. package/dist/theme/useColorScheme.js.map +0 -1
  1379. package/dist/theme/useColorSchemeMetaTag.js.map +0 -1
  1380. package/dist/theme/useColorSchemeProvider.js.map +0 -1
  1381. package/dist/theme/usePrefersColorScheme.js.map +0 -1
  1382. package/dist/theme/utils.js.map +0 -1
  1383. package/dist/tooltip/Tooltip.js.map +0 -1
  1384. package/dist/tooltip/TooltipHoverModeProvider.js.map +0 -1
  1385. package/dist/tooltip/constants.js.map +0 -1
  1386. package/dist/tooltip/tooltipStyles.js.map +0 -1
  1387. package/dist/tooltip/useTooltip.js.map +0 -1
  1388. package/dist/tooltip/useTooltipPosition.js.map +0 -1
  1389. package/dist/tooltip/utils.js.map +0 -1
  1390. package/dist/transition/CSSTransition.js.map +0 -1
  1391. package/dist/transition/Collapse.js.map +0 -1
  1392. package/dist/transition/CrossFade.js.map +0 -1
  1393. package/dist/transition/ScaleTransition.js.map +0 -1
  1394. package/dist/transition/SkeletonPlaceholder.js +0 -126
  1395. package/dist/transition/SkeletonPlaceholder.js.map +0 -1
  1396. package/dist/transition/Slide.js.map +0 -1
  1397. package/dist/transition/SlideContainer.js.map +0 -1
  1398. package/dist/transition/collapseStyles.js.map +0 -1
  1399. package/dist/transition/config.js.map +0 -1
  1400. package/dist/transition/maxWidthTransition.js.map +0 -1
  1401. package/dist/transition/types.js.map +0 -1
  1402. package/dist/transition/useCSSTransition.js.map +0 -1
  1403. package/dist/transition/useCarousel.js.map +0 -1
  1404. package/dist/transition/useCollapseTransition.js.map +0 -1
  1405. package/dist/transition/useCrossFadeTransition.js.map +0 -1
  1406. package/dist/transition/useMaxWidthTransition.js.map +0 -1
  1407. package/dist/transition/useScaleTransition.js.map +0 -1
  1408. package/dist/transition/useSkeletonPlaceholder.js +0 -68
  1409. package/dist/transition/useSkeletonPlaceholder.js.map +0 -1
  1410. package/dist/transition/useSlideTransition.js.map +0 -1
  1411. package/dist/transition/useTransition.js.map +0 -1
  1412. package/dist/transition/utils.js.map +0 -1
  1413. package/dist/tree/DefaultTreeItemRenderer.js.map +0 -1
  1414. package/dist/tree/Tree.js.map +0 -1
  1415. package/dist/tree/TreeGroup.js.map +0 -1
  1416. package/dist/tree/TreeItem.js +0 -174
  1417. package/dist/tree/TreeItem.js.map +0 -1
  1418. package/dist/tree/TreeItemExpander.js.map +0 -1
  1419. package/dist/tree/TreeProvider.js.map +0 -1
  1420. package/dist/tree/styles.js +0 -59
  1421. package/dist/tree/styles.js.map +0 -1
  1422. package/dist/tree/types.js.map +0 -1
  1423. package/dist/tree/useTree.js.map +0 -1
  1424. package/dist/tree/useTreeExpansion.js.map +0 -1
  1425. package/dist/tree/useTreeItems.js.map +0 -1
  1426. package/dist/tree/useTreeMovement.js.map +0 -1
  1427. package/dist/tree/useTreeSelection.js.map +0 -1
  1428. package/dist/tree/utils.js.map +0 -1
  1429. package/dist/types.js +0 -6
  1430. package/dist/types.js.map +0 -1
  1431. package/dist/typography/SrOnly.js.map +0 -1
  1432. package/dist/typography/TextContainer.js.map +0 -1
  1433. package/dist/typography/Typography.js.map +0 -1
  1434. package/dist/typography/WritingDirectionProvider.js.map +0 -1
  1435. package/dist/useAsyncAction.js.map +0 -1
  1436. package/dist/useDebouncedFunction.js.map +0 -1
  1437. package/dist/useDropzone.js.map +0 -1
  1438. package/dist/useEnsuredId.js.map +0 -1
  1439. package/dist/useEnsuredRef.js.map +0 -1
  1440. package/dist/useEnsuredState.js.map +0 -1
  1441. package/dist/useHtmlClassName.js.map +0 -1
  1442. package/dist/useIntersectionObserver.js.map +0 -1
  1443. package/dist/useIsomorphicLayoutEffect.js.map +0 -1
  1444. package/dist/useLocalStorage.js.map +0 -1
  1445. package/dist/useOrientation.js.map +0 -1
  1446. package/dist/usePageInactive.js.map +0 -1
  1447. package/dist/useResizeListener.js +0 -70
  1448. package/dist/useResizeListener.js.map +0 -1
  1449. package/dist/useResizeObserver.js +0 -173
  1450. package/dist/useResizeObserver.js.map +0 -1
  1451. package/dist/useThrottledFunction.js.map +0 -1
  1452. package/dist/useToggle.js.map +0 -1
  1453. package/dist/useUnmounted.js.map +0 -1
  1454. package/dist/useWindowSize.js +0 -63
  1455. package/dist/useWindowSize.js.map +0 -1
  1456. package/dist/utils/RenderRecursively.js.map +0 -1
  1457. package/dist/utils/alphaNumericSort.js.map +0 -1
  1458. package/dist/utils/applyRef.js.map +0 -1
  1459. package/dist/utils/bem.js.map +0 -1
  1460. package/dist/utils/filters.js.map +0 -1
  1461. package/dist/utils/getClientPosition.js.map +0 -1
  1462. package/dist/utils/getPercentage.js.map +0 -1
  1463. package/dist/utils/getRangeDefaultValue.js +0 -23
  1464. package/dist/utils/getRangeDefaultValue.js.map +0 -1
  1465. package/dist/utils/getRangeSteps.js +0 -17
  1466. package/dist/utils/getRangeSteps.js.map +0 -1
  1467. package/dist/utils/identity.js.map +0 -1
  1468. package/dist/utils/isElementVisible.js.map +0 -1
  1469. package/dist/utils/loop.js.map +0 -1
  1470. package/dist/utils/nearest.js +0 -27
  1471. package/dist/utils/nearest.js.map +0 -1
  1472. package/dist/utils/parseCssLengthUnit.js.map +0 -1
  1473. package/dist/utils/randomInt.js.map +0 -1
  1474. package/dist/utils/wait.js.map +0 -1
  1475. package/dist/utils/withinRange.js.map +0 -1
  1476. package/dist/window-splitter/WindowSplitter.js.map +0 -1
  1477. package/dist/window-splitter/useWindowSplitter.js +0 -67
  1478. package/dist/window-splitter/useWindowSplitter.js.map +0 -1
  1479. /package/dist/{CoreProviders.js → src/CoreProviders.js} +0 -0
  1480. /package/dist/{NoSsr.js → src/NoSsr.js} +0 -0
  1481. /package/dist/{SsrProvider.js → src/SsrProvider.js} +0 -0
  1482. /package/dist/{app-bar → src/app-bar}/AppBarTitle.js +0 -0
  1483. /package/dist/{avatar → src/avatar}/Avatar.js +0 -0
  1484. /package/dist/{avatar → src/avatar}/styles.js +0 -0
  1485. /package/dist/{badge → src/badge}/Badge.js +0 -0
  1486. /package/dist/{box → src/box}/Box.js +0 -0
  1487. /package/dist/{box → src/box}/styles.js +0 -0
  1488. /package/dist/{button → src/button}/AsyncButton.js +0 -0
  1489. /package/dist/{button → src/button}/Button.js +0 -0
  1490. /package/dist/{button → src/button}/ButtonUnstyled.js +0 -0
  1491. /package/dist/{button → src/button}/FloatingActionButton.js +0 -0
  1492. /package/dist/{button → src/button}/buttonStyles.js +0 -0
  1493. /package/dist/{button → src/button}/buttonUnstyledStyles.js +0 -0
  1494. /package/dist/{card → src/card}/CardFooter.js +0 -0
  1495. /package/dist/{card → src/card}/CardHeader.js +0 -0
  1496. /package/dist/{card → src/card}/CardSubtitle.js +0 -0
  1497. /package/dist/{card → src/card}/CardTitle.js +0 -0
  1498. /package/dist/{chip → src/chip}/Chip.js +0 -0
  1499. /package/dist/{chip → src/chip}/styles.js +0 -0
  1500. /package/dist/{cssUtils.js → src/cssUtils.js} +0 -0
  1501. /package/dist/{delegateEvent.js → src/delegateEvent.js} +0 -0
  1502. /package/dist/{dialog → src/dialog}/Dialog.js +0 -0
  1503. /package/dist/{dialog → src/dialog}/DialogContainer.js +0 -0
  1504. /package/dist/{dialog → src/dialog}/DialogContent.js +0 -0
  1505. /package/dist/{dialog → src/dialog}/DialogFooter.js +0 -0
  1506. /package/dist/{dialog → src/dialog}/DialogHeader.js +0 -0
  1507. /package/dist/{dialog → src/dialog}/DialogTitle.js +0 -0
  1508. /package/dist/{dialog → src/dialog}/FixedDialog.js +0 -0
  1509. /package/dist/{dialog → src/dialog}/NestedDialogProvider.js +0 -0
  1510. /package/dist/{dialog → src/dialog}/styles.js +0 -0
  1511. /package/dist/{divider → src/divider}/Divider.js +0 -0
  1512. /package/dist/{divider → src/divider}/styles.js +0 -0
  1513. /package/dist/{expansion-panel → src/expansion-panel}/ExpansionList.js +0 -0
  1514. /package/dist/{expansion-panel → src/expansion-panel}/ExpansionPanel.js +0 -0
  1515. /package/dist/{expansion-panel → src/expansion-panel}/ExpansionPanelHeader.js +0 -0
  1516. /package/dist/{expansion-panel → src/expansion-panel}/useExpansionList.js +0 -0
  1517. /package/dist/{focus → src/focus}/useFocusContainer.js +0 -0
  1518. /package/dist/{focus → src/focus}/utils.js +0 -0
  1519. /package/dist/{form → src/form}/Checkbox.js +0 -0
  1520. /package/dist/{form → src/form}/Fieldset.js +0 -0
  1521. /package/dist/{form → src/form}/FileInput.js +0 -0
  1522. /package/dist/{form → src/form}/Form.js +0 -0
  1523. /package/dist/{form → src/form}/FormMessage.js +0 -0
  1524. /package/dist/{form → src/form}/FormMessageContainer.js +0 -0
  1525. /package/dist/{form → src/form}/FormMessageCounter.js +0 -0
  1526. /package/dist/{form → src/form}/InputToggle.js +0 -0
  1527. /package/dist/{form → src/form}/InputToggleIcon.js +0 -0
  1528. /package/dist/{form → src/form}/Label.js +0 -0
  1529. /package/dist/{form → src/form}/Legend.js +0 -0
  1530. /package/dist/{form → src/form}/MenuItemCheckbox.js +0 -0
  1531. /package/dist/{form → src/form}/MenuItemFileInput.js +0 -0
  1532. /package/dist/{form → src/form}/MenuItemInputToggle.js +0 -0
  1533. /package/dist/{form → src/form}/MenuItemRadio.js +0 -0
  1534. /package/dist/{form → src/form}/MenuItemSwitch.js +0 -0
  1535. /package/dist/{form → src/form}/MenuItemTextField.js +0 -0
  1536. /package/dist/{form → src/form}/NativeSelect.js +0 -0
  1537. /package/dist/{form → src/form}/OptGroup.js +0 -0
  1538. /package/dist/{form → src/form}/Option.js +0 -0
  1539. /package/dist/{form → src/form}/Password.js +0 -0
  1540. /package/dist/{form → src/form}/Radio.js +0 -0
  1541. /package/dist/{form → src/form}/SelectValue.js +0 -0
  1542. /package/dist/{form → src/form}/Slider.js +0 -0
  1543. /package/dist/{form → src/form}/SliderContainer.js +0 -0
  1544. /package/dist/{form → src/form}/SliderMark.js +0 -0
  1545. /package/dist/{form → src/form}/SliderMarkLabel.js +0 -0
  1546. /package/dist/{form → src/form}/SliderThumb.js +0 -0
  1547. /package/dist/{form → src/form}/SliderTrack.js +0 -0
  1548. /package/dist/{form → src/form}/SliderValueMarks.js +0 -0
  1549. /package/dist/{form → src/form}/SliderValueTooltip.js +0 -0
  1550. /package/dist/{form → src/form}/Switch.js +0 -0
  1551. /package/dist/{form → src/form}/SwitchTrack.js +0 -0
  1552. /package/dist/{form → src/form}/TextArea.js +0 -0
  1553. /package/dist/{form → src/form}/TextField.js +0 -0
  1554. /package/dist/{form → src/form}/TextFieldAddon.js +0 -0
  1555. /package/dist/{form → src/form}/TextFieldContainer.js +0 -0
  1556. /package/dist/{form → src/form}/TextFieldContainerStyles.js +0 -0
  1557. /package/dist/{form → src/form}/fileUtils.js +0 -0
  1558. /package/dist/{form → src/form}/formConfig.js +0 -0
  1559. /package/dist/{form → src/form}/formMessageStyles.js +0 -0
  1560. /package/dist/{form → src/form}/inputToggleStyles.js +0 -0
  1561. /package/dist/{form → src/form}/nativeSelectStyles.js +0 -0
  1562. /package/dist/{form → src/form}/optionStyles.js +0 -0
  1563. /package/dist/{form → src/form}/passwordStyles.js +0 -0
  1564. /package/dist/{form → src/form}/selectStyles.js +0 -0
  1565. /package/dist/{form → src/form}/selectUtils.js +0 -0
  1566. /package/dist/{form → src/form}/sliderUtils.js +0 -0
  1567. /package/dist/{form → src/form}/switchStyles.js +0 -0
  1568. /package/dist/{form → src/form}/textAreaStyles.js +0 -0
  1569. /package/dist/{form → src/form}/textFieldStyles.js +0 -0
  1570. /package/dist/{form → src/form}/types.js +0 -0
  1571. /package/dist/{form → src/form}/useCheckboxGroup.js +0 -0
  1572. /package/dist/{form → src/form}/useFileUpload.js +0 -0
  1573. /package/dist/{form → src/form}/useListboxProvider.js +0 -0
  1574. /package/dist/{form → src/form}/useNumberField.js +0 -0
  1575. /package/dist/{form → src/form}/useRadioGroup.js +0 -0
  1576. /package/dist/{form → src/form}/useRangeSlider.js +0 -0
  1577. /package/dist/{form → src/form}/useResizingTextArea.js +0 -0
  1578. /package/dist/{form → src/form}/useSlider.js +0 -0
  1579. /package/dist/{form → src/form}/useTextField.js +0 -0
  1580. /package/dist/{form → src/form}/utils.js +0 -0
  1581. /package/dist/{form → src/form}/validation.js +0 -0
  1582. /package/dist/{hoverMode → src/hoverMode}/useHoverMode.js +0 -0
  1583. /package/dist/{hoverMode → src/hoverMode}/useHoverModeProvider.js +0 -0
  1584. /package/dist/{icon → src/icon}/FontIcon.js +0 -0
  1585. /package/dist/{icon → src/icon}/MaterialIcon.js +0 -0
  1586. /package/dist/{icon → src/icon}/MaterialSymbol.js +0 -0
  1587. /package/dist/{icon → src/icon}/SVGIcon.js +0 -0
  1588. /package/dist/{icon → src/icon}/TextIconSpacing.js +0 -0
  1589. /package/dist/{icon → src/icon}/iconConfig.js +0 -0
  1590. /package/dist/{icon → src/icon}/material.js +0 -0
  1591. /package/dist/{icon → src/icon}/materialConfig.js +0 -0
  1592. /package/dist/{icon → src/icon}/styles.js +0 -0
  1593. /package/dist/{interaction → src/interaction}/Ripple.js +0 -0
  1594. /package/dist/{interaction → src/interaction}/RippleContainer.js +0 -0
  1595. /package/dist/{interaction → src/interaction}/UserInteractionModeProvider.js +0 -0
  1596. /package/dist/{interaction → src/interaction}/config.js +0 -0
  1597. /package/dist/{interaction → src/interaction}/types.js +0 -0
  1598. /package/dist/{interaction → src/interaction}/useElementInteraction.js +0 -0
  1599. /package/dist/{interaction → src/interaction}/useHigherContrastChildren.js +0 -0
  1600. /package/dist/{interaction → src/interaction}/utils.js +0 -0
  1601. /package/dist/{layout → src/layout}/LayoutAppBar.js +0 -0
  1602. /package/dist/{layout → src/layout}/LayoutNav.js +0 -0
  1603. /package/dist/{layout → src/layout}/LayoutWindowSplitter.js +0 -0
  1604. /package/dist/{layout → src/layout}/Main.js +0 -0
  1605. /package/dist/{layout → src/layout}/layoutNavStyles.js +0 -0
  1606. /package/dist/{layout → src/layout}/layoutWindowSplitterStyles.js +0 -0
  1607. /package/dist/{layout → src/layout}/mainStyles.js +0 -0
  1608. /package/dist/{layout → src/layout}/useExpandableLayout.js +0 -0
  1609. /package/dist/{layout → src/layout}/useHorizontalLayoutTransition.js +0 -0
  1610. /package/dist/{layout → src/layout}/useLayoutTree.js +0 -0
  1611. /package/dist/{layout → src/layout}/useLayoutWindowSplitter.js +0 -0
  1612. /package/dist/{layout → src/layout}/useMainTabIndex.js +0 -0
  1613. /package/dist/{layout → src/layout}/useResizableLayout.js +0 -0
  1614. /package/dist/{layout → src/layout}/useTemporaryLayout.js +0 -0
  1615. /package/dist/{link → src/link}/Link.js +0 -0
  1616. /package/dist/{link → src/link}/SkipToMainContent.js +0 -0
  1617. /package/dist/{link → src/link}/styles.js +0 -0
  1618. /package/dist/{list → src/list}/List.js +0 -0
  1619. /package/dist/{list → src/list}/ListItemText.js +0 -0
  1620. /package/dist/{list → src/list}/ListSubheader.js +0 -0
  1621. /package/dist/{list → src/list}/types.js +0 -0
  1622. /package/dist/{media-queries → src/media-queries}/AppSizeProvider.js +0 -0
  1623. /package/dist/{media-queries → src/media-queries}/appSize.js +0 -0
  1624. /package/dist/{media-queries → src/media-queries}/useMediaQuery.js +0 -0
  1625. /package/dist/{menu → src/menu}/DropdownMenu.js +0 -0
  1626. /package/dist/{menu → src/menu}/Menu.js +0 -0
  1627. /package/dist/{menu → src/menu}/MenuBar.js +0 -0
  1628. /package/dist/{menu → src/menu}/MenuButton.js +0 -0
  1629. /package/dist/{menu → src/menu}/MenuConfigurationProvider.js +0 -0
  1630. /package/dist/{menu → src/menu}/MenuItem.js +0 -0
  1631. /package/dist/{menu → src/menu}/MenuItemButton.js +0 -0
  1632. /package/dist/{menu → src/menu}/MenuItemGroup.js +0 -0
  1633. /package/dist/{menu → src/menu}/MenuItemSeparator.js +0 -0
  1634. /package/dist/{menu → src/menu}/MenuSheet.js +0 -0
  1635. /package/dist/{menu → src/menu}/MenuVisibilityProvider.js +0 -0
  1636. /package/dist/{menu → src/menu}/MenuWidget.js +0 -0
  1637. /package/dist/{menu → src/menu}/MenuWidgetKeyboardProvider.js +0 -0
  1638. /package/dist/{menu → src/menu}/useContextMenu.js +0 -0
  1639. /package/dist/{menu → src/menu}/useMenuBarProvider.js +0 -0
  1640. /package/dist/{menu → src/menu}/utils.js +0 -0
  1641. /package/dist/{movement → src/movement}/constants.js +0 -0
  1642. /package/dist/{movement → src/movement}/findMatchIndex.js +0 -0
  1643. /package/dist/{movement → src/movement}/types.js +0 -0
  1644. /package/dist/{movement → src/movement}/useKeyboardMovementProvider.js +0 -0
  1645. /package/dist/{movement → src/movement}/utils.js +0 -0
  1646. /package/dist/{overlay → src/overlay}/Overlay.js +0 -0
  1647. /package/dist/{overlay → src/overlay}/overlayStyles.js +0 -0
  1648. /package/dist/{portal → src/portal}/Portal.js +0 -0
  1649. /package/dist/{positioning → src/positioning}/constants.js +0 -0
  1650. /package/dist/{positioning → src/positioning}/createHorizontalPosition.js +0 -0
  1651. /package/dist/{positioning → src/positioning}/createVerticalPosition.js +0 -0
  1652. /package/dist/{positioning → src/positioning}/getFixedPosition.js +0 -0
  1653. /package/dist/{positioning → src/positioning}/types.js +0 -0
  1654. /package/dist/{positioning → src/positioning}/useFixedPositioning.js +0 -0
  1655. /package/dist/{positioning → src/positioning}/utils.js +0 -0
  1656. /package/dist/{progress → src/progress}/CircularProgress.js +0 -0
  1657. /package/dist/{progress → src/progress}/LinearProgress.js +0 -0
  1658. /package/dist/{progress → src/progress}/getProgressA11y.js +0 -0
  1659. /package/dist/{progress → src/progress}/types.js +0 -0
  1660. /package/dist/{responsive-item → src/responsive-item}/ResponsiveItemContainer.js +0 -0
  1661. /package/dist/{responsive-item → src/responsive-item}/ResponsiveItemOverlay.js +0 -0
  1662. /package/dist/{responsive-item → src/responsive-item}/styles.js +0 -0
  1663. /package/dist/{scroll → src/scroll}/ScrollLock.js +0 -0
  1664. /package/dist/{scroll → src/scroll}/getScrollbarWidth.js +0 -0
  1665. /package/dist/{scroll → src/scroll}/useScrollLock.js +0 -0
  1666. /package/dist/{segmented-button → src/segmented-button}/SegmentedButton.js +0 -0
  1667. /package/dist/{segmented-button → src/segmented-button}/SegmentedButtonContainer.js +0 -0
  1668. /package/dist/{segmented-button → src/segmented-button}/segmentedButtonContainerStyles.js +0 -0
  1669. /package/dist/{segmented-button → src/segmented-button}/segmentedButtonStyles.js +0 -0
  1670. /package/dist/{sheet → src/sheet}/Sheet.js +0 -0
  1671. /package/dist/{sheet → src/sheet}/styles.js +0 -0
  1672. /package/dist/{snackbar → src/snackbar}/DefaultToastRenderer.js +0 -0
  1673. /package/dist/{snackbar → src/snackbar}/Snackbar.js +0 -0
  1674. /package/dist/{snackbar → src/snackbar}/Toast.js +0 -0
  1675. /package/dist/{snackbar → src/snackbar}/ToastActionButton.js +0 -0
  1676. /package/dist/{snackbar → src/snackbar}/ToastCloseButton.js +0 -0
  1677. /package/dist/{snackbar → src/snackbar}/ToastContent.js +0 -0
  1678. /package/dist/{snackbar → src/snackbar}/ToastManager.js +0 -0
  1679. /package/dist/{snackbar → src/snackbar}/ToastManagerProvider.js +0 -0
  1680. /package/dist/{snackbar → src/snackbar}/snackbarStyles.js +0 -0
  1681. /package/dist/{snackbar → src/snackbar}/toastContentStyles.js +0 -0
  1682. /package/dist/{snackbar → src/snackbar}/toastStyles.js +0 -0
  1683. /package/dist/{snackbar → src/snackbar}/useCurrentToastActions.js +0 -0
  1684. /package/dist/{suspense → src/suspense}/CircularProgressSuspense.js +0 -0
  1685. /package/dist/{suspense → src/suspense}/NullSuspense.js +0 -0
  1686. /package/dist/{table → src/table}/Table.js +0 -0
  1687. /package/dist/{table → src/table}/TableBody.js +0 -0
  1688. /package/dist/{table → src/table}/TableCell.js +0 -0
  1689. /package/dist/{table → src/table}/TableCellContent.js +0 -0
  1690. /package/dist/{table → src/table}/TableConfigurationProvider.js +0 -0
  1691. /package/dist/{table → src/table}/TableContainer.js +0 -0
  1692. /package/dist/{table → src/table}/TableContainerProvider.js +0 -0
  1693. /package/dist/{table → src/table}/TableFooter.js +0 -0
  1694. /package/dist/{table → src/table}/TableHeader.js +0 -0
  1695. /package/dist/{table → src/table}/TableRow.js +0 -0
  1696. /package/dist/{table → src/table}/tableCellStyles.js +0 -0
  1697. /package/dist/{table → src/table}/tableContainerStyles.js +0 -0
  1698. /package/dist/{table → src/table}/tableFooterStyles.js +0 -0
  1699. /package/dist/{table → src/table}/tableHeaderStyles.js +0 -0
  1700. /package/dist/{table → src/table}/tableRowStyles.js +0 -0
  1701. /package/dist/{table → src/table}/tableStyles.js +0 -0
  1702. /package/dist/{table → src/table}/types.js +0 -0
  1703. /package/dist/{tabs → src/tabs}/TabList.js +0 -0
  1704. /package/dist/{tabs → src/tabs}/TabListScrollButton.js +0 -0
  1705. /package/dist/{tabs → src/tabs}/tabListScrollButtonStyles.js +0 -0
  1706. /package/dist/{tabs → src/tabs}/useTabs.js +0 -0
  1707. /package/dist/{tabs → src/tabs}/utils.js +0 -0
  1708. /package/dist/{test-utils → src/test-utils}/IntersectionObserver.js +0 -0
  1709. /package/dist/{test-utils → src/test-utils}/ResizeObserver.js +0 -0
  1710. /package/dist/{test-utils → src/test-utils}/data-testid.js +0 -0
  1711. /package/dist/{test-utils → src/test-utils}/index.js +0 -0
  1712. /package/dist/{test-utils → src/test-utils}/jest-setup.js +0 -0
  1713. /package/dist/{test-utils → src/test-utils}/matchMedia.js +0 -0
  1714. /package/dist/{test-utils → src/test-utils}/polyfills/IntersectionObserver.js +0 -0
  1715. /package/dist/{test-utils → src/test-utils}/polyfills/ResizeObserver.js +0 -0
  1716. /package/dist/{test-utils → src/test-utils}/polyfills/index.js +0 -0
  1717. /package/dist/{test-utils → src/test-utils}/polyfills/matchMedia.js +0 -0
  1718. /package/dist/{test-utils → src/test-utils}/polyfills/offsetParent.js +0 -0
  1719. /package/dist/{test-utils → src/test-utils}/polyfills/scrollIntoView.js +0 -0
  1720. /package/dist/{test-utils → src/test-utils}/render.js +0 -0
  1721. /package/dist/{test-utils → src/test-utils}/timers.js +0 -0
  1722. /package/dist/{theme → src/theme}/LocalStorageColorSchemeProvider.js +0 -0
  1723. /package/dist/{theme → src/theme}/ThemeProvider.js +0 -0
  1724. /package/dist/{theme → src/theme}/colors.js +0 -0
  1725. /package/dist/{theme → src/theme}/cssVars.js +0 -0
  1726. /package/dist/{theme → src/theme}/types.js +0 -0
  1727. /package/dist/{theme → src/theme}/useCSSVariables.js +0 -0
  1728. /package/dist/{theme → src/theme}/useColorScheme.js +0 -0
  1729. /package/dist/{theme → src/theme}/useColorSchemeMetaTag.js +0 -0
  1730. /package/dist/{theme → src/theme}/useColorSchemeProvider.js +0 -0
  1731. /package/dist/{theme → src/theme}/usePrefersColorScheme.js +0 -0
  1732. /package/dist/{theme → src/theme}/utils.js +0 -0
  1733. /package/dist/{tooltip → src/tooltip}/Tooltip.js +0 -0
  1734. /package/dist/{tooltip → src/tooltip}/TooltipHoverModeProvider.js +0 -0
  1735. /package/dist/{tooltip → src/tooltip}/constants.js +0 -0
  1736. /package/dist/{tooltip → src/tooltip}/tooltipStyles.js +0 -0
  1737. /package/dist/{tooltip → src/tooltip}/useTooltip.js +0 -0
  1738. /package/dist/{tooltip → src/tooltip}/useTooltipPosition.js +0 -0
  1739. /package/dist/{tooltip → src/tooltip}/utils.js +0 -0
  1740. /package/dist/{transition → src/transition}/CSSTransition.js +0 -0
  1741. /package/dist/{transition → src/transition}/Collapse.js +0 -0
  1742. /package/dist/{transition → src/transition}/CrossFade.js +0 -0
  1743. /package/dist/{transition → src/transition}/ScaleTransition.js +0 -0
  1744. /package/dist/{transition → src/transition}/Slide.js +0 -0
  1745. /package/dist/{transition → src/transition}/SlideContainer.js +0 -0
  1746. /package/dist/{transition → src/transition}/collapseStyles.js +0 -0
  1747. /package/dist/{transition → src/transition}/config.js +0 -0
  1748. /package/dist/{transition → src/transition}/maxWidthTransition.js +0 -0
  1749. /package/dist/{transition → src/transition}/types.js +0 -0
  1750. /package/dist/{transition → src/transition}/useCSSTransition.js +0 -0
  1751. /package/dist/{transition → src/transition}/useCarousel.js +0 -0
  1752. /package/dist/{transition → src/transition}/useCollapseTransition.js +0 -0
  1753. /package/dist/{transition → src/transition}/useCrossFadeTransition.js +0 -0
  1754. /package/dist/{transition → src/transition}/useMaxWidthTransition.js +0 -0
  1755. /package/dist/{transition → src/transition}/useScaleTransition.js +0 -0
  1756. /package/dist/{transition → src/transition}/useSlideTransition.js +0 -0
  1757. /package/dist/{transition → src/transition}/useTransition.js +0 -0
  1758. /package/dist/{transition → src/transition}/utils.js +0 -0
  1759. /package/dist/{tree → src/tree}/DefaultTreeItemRenderer.js +0 -0
  1760. /package/dist/{tree → src/tree}/Tree.js +0 -0
  1761. /package/dist/{tree → src/tree}/TreeGroup.js +0 -0
  1762. /package/dist/{tree → src/tree}/TreeItemExpander.js +0 -0
  1763. /package/dist/{tree → src/tree}/TreeProvider.js +0 -0
  1764. /package/dist/{tree → src/tree}/types.js +0 -0
  1765. /package/dist/{tree → src/tree}/useTree.js +0 -0
  1766. /package/dist/{tree → src/tree}/useTreeExpansion.js +0 -0
  1767. /package/dist/{tree → src/tree}/useTreeItems.js +0 -0
  1768. /package/dist/{tree → src/tree}/useTreeMovement.js +0 -0
  1769. /package/dist/{tree → src/tree}/useTreeSelection.js +0 -0
  1770. /package/dist/{tree → src/tree}/utils.js +0 -0
  1771. /package/dist/{typography → src/typography}/SrOnly.js +0 -0
  1772. /package/dist/{typography → src/typography}/TextContainer.js +0 -0
  1773. /package/dist/{typography → src/typography}/Typography.js +0 -0
  1774. /package/dist/{typography → src/typography}/WritingDirectionProvider.js +0 -0
  1775. /package/dist/{useAsyncAction.js → src/useAsyncAction.js} +0 -0
  1776. /package/dist/{useDebouncedFunction.js → src/useDebouncedFunction.js} +0 -0
  1777. /package/dist/{useDropzone.js → src/useDropzone.js} +0 -0
  1778. /package/dist/{useEnsuredId.js → src/useEnsuredId.js} +0 -0
  1779. /package/dist/{useEnsuredRef.js → src/useEnsuredRef.js} +0 -0
  1780. /package/dist/{useEnsuredState.js → src/useEnsuredState.js} +0 -0
  1781. /package/dist/{useHtmlClassName.js → src/useHtmlClassName.js} +0 -0
  1782. /package/dist/{useIntersectionObserver.js → src/useIntersectionObserver.js} +0 -0
  1783. /package/dist/{useIsomorphicLayoutEffect.js → src/useIsomorphicLayoutEffect.js} +0 -0
  1784. /package/dist/{useLocalStorage.js → src/useLocalStorage.js} +0 -0
  1785. /package/dist/{useOrientation.js → src/useOrientation.js} +0 -0
  1786. /package/dist/{usePageInactive.js → src/usePageInactive.js} +0 -0
  1787. /package/dist/{useThrottledFunction.js → src/useThrottledFunction.js} +0 -0
  1788. /package/dist/{useToggle.js → src/useToggle.js} +0 -0
  1789. /package/dist/{useUnmounted.js → src/useUnmounted.js} +0 -0
  1790. /package/dist/{utils → src/utils}/RenderRecursively.js +0 -0
  1791. /package/dist/{utils → src/utils}/alphaNumericSort.js +0 -0
  1792. /package/dist/{utils → src/utils}/applyRef.js +0 -0
  1793. /package/dist/{utils → src/utils}/bem.js +0 -0
  1794. /package/dist/{utils → src/utils}/filters.js +0 -0
  1795. /package/dist/{utils → src/utils}/getClientPosition.js +0 -0
  1796. /package/dist/{utils → src/utils}/getPercentage.js +0 -0
  1797. /package/dist/{utils → src/utils}/identity.js +0 -0
  1798. /package/dist/{utils → src/utils}/isElementVisible.js +0 -0
  1799. /package/dist/{utils → src/utils}/loop.js +0 -0
  1800. /package/dist/{utils → src/utils}/parseCssLengthUnit.js +0 -0
  1801. /package/dist/{utils → src/utils}/randomInt.js +0 -0
  1802. /package/dist/{utils → src/utils}/wait.js +0 -0
  1803. /package/dist/{utils → src/utils}/withinRange.js +0 -0
  1804. /package/dist/{window-splitter → src/window-splitter}/WindowSplitter.js +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useDropzone.ts"],"sourcesContent":["\"use client\";\nimport type { DragEvent } from \"react\";\nimport { useEffect, useRef, useState } from \"react\";\n\nconst noop = (): void => {\n // do nothing\n};\n\n/**\n * @remarks\n * \\@since 5.1.3\n * \\@since 6.0.0 The element type is dynamically inferred on each handler\n * instead of the `DropzoneHandlers` type.\n */\nexport interface DropzoneHandlers {\n onDrop<E extends HTMLElement>(event: DragEvent<E>): void;\n onDragEnter?<E extends HTMLElement>(event: DragEvent<E>): void;\n onDragOver?<E extends HTMLElement>(event: DragEvent<E>): void;\n onDragLeave?<E extends HTMLElement>(event: DragEvent<E>): void;\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface DropzoneOptions extends DropzoneHandlers {\n /**\n * Set this to `true` if you do not need to capture drag events from outside\n * the window. i.e. Dragging files into the dropzone.\n *\n * @defaultValue `false`\n * @see {@link DropzoneHookReturnValue.isDragging}\n */\n disableDragging?: boolean;\n}\n\n/**\n * @remarks\n * \\@since 2.9.0\n * \\@since 6.0.0 Returns an object instead of an ordered array of\n * `[isOver: boolean, dropzoneHandlers: DropzoneHandlers]`. Also returns a new\n * `isDragging` state.\n */\nexport interface DropzoneHookReturnValue {\n /**\n * This will be `true` when the user is dragging something over the dropzone\n * target.\n */\n isOver: boolean;\n\n /**\n * This will be `true` when the user is dragging anything within the document.\n * The main use case for this is detecting when a user is dragging a file into\n * the document so you can help highlight the dropzone area.\n *\n * This will always be `false` if {@link DropzoneOptions.disableDragging} is\n * `true`.\n */\n isDragging: boolean;\n\n /**\n * The event handlers that should be passed to the dropzone target.\n */\n dropzoneHandlers: Required<DropzoneHandlers>;\n}\n\n/**\n * @example\n * Simple Example\n * ```tsx\n * import { useDropzone, useFileUpload } from \"@react-md/core\"\n * import type { CSSProperties, ReactElement } from \"react\";\n *\n * const style: CSSProperties = {\n * border: '1px solid blue',\n * };\n *\n * function Example(): ReactElement {\n * const { onDrop } = useFileUpload()\n * const { isOver, dropzoneHandlers } = useDropzone({\n * onDrop(event) {\n * // normally use the `onDrop` behavior from `useFileUpload` to upload\n * // files:\n * // onDrop(event);\n * },\n * disableDragging: true,\n * });\n *\n * return (\n * <div {...dropzoneHandlers} style={isOver ? style : {}}>\n * Drag and drop some files!\n * {isOver && <UploadSVGIcon />}\n * </div>\n * );\n * }\n * ```\n *\n * @example\n * Dragging Example\n * ```tsx\n * import { useDropzone, useFileUpload } from \"@react-md/core\"\n * import type { CSSProperties, ReactElement } from \"react\";\n *\n * const draggingStyle: CSSProperties = {\n * backgroundColor: \"orange\",\n * };\n * const overStyle: CSSProperties = {\n * border: '1px solid blue',\n * };\n *\n * function Example(): ReactElement {\n * const { onDrop } = useFileUpload()\n * const { isOver, isDragging, dropzoneHandlers } = useDropzone({\n * onDrop(event) {\n * // normally use the `onDrop` behavior from `useFileUpload` to upload\n * // files:\n * // onDrop(event);\n * },\n * });\n *\n * return (\n * <div\n * {...dropzoneHandlers}\n * style={{\n * ...(isDragging && draggingStyle),\n * ...(isOver && overStyle),\n * }}\n * >\n * Drag and drop some files!\n * {isOver && <UploadSVGIcon />}\n * </div>\n * );\n * }\n * ```\n *\n * @remarks\n * \\@since 2.9.0\n * \\@since 6.0.0 Supports document-level dragging flag;\n */\nexport function useDropzone(options: DropzoneOptions): DropzoneHookReturnValue {\n const {\n onDrop,\n onDragOver = noop,\n onDragEnter = noop,\n onDragLeave = noop,\n disableDragging = false,\n } = options;\n\n const [isOver, setOver] = useState(false);\n const [isDragging, setDragging] = useState(false);\n const draggingTimeout = useRef<number | undefined>();\n\n useEffect(() => {\n if (disableDragging) {\n return;\n }\n\n const startDragging = (): void => {\n setDragging(true);\n };\n\n // Browsers sometimes don't trigger a dragleave event for the entire\n // document, so we have to work around that by using the `dragover` event\n // instead. The `dragover` event will continually fire within the window\n // until the user drops the file or moves the file outside of the window.\n //\n // So we can consider the\n const handler = (): void => {\n window.clearTimeout(draggingTimeout.current);\n draggingTimeout.current = window.setTimeout(() => {\n setDragging(false);\n }, 100);\n };\n\n window.addEventListener(\"dragenter\", startDragging);\n window.addEventListener(\"dragover\", handler);\n return () => {\n window.clearTimeout(draggingTimeout.current);\n window.removeEventListener(\"dragenter\", startDragging);\n window.removeEventListener(\"dragover\", handler);\n };\n }, [disableDragging]);\n\n return {\n isOver,\n isDragging,\n dropzoneHandlers: {\n // Note: need to call `event.stopPropagation()` and\n // `event.preventDefault())` for each of these handlers to prevent the\n // default browser behavior when dropping. Only calling within `onDrop`\n // does not work.\n //\n // i.e. dropping an image would preview that image in the current\n // window/tab instead of triggering the drop event.\n onDrop(event) {\n event.preventDefault();\n event.stopPropagation();\n\n window.clearTimeout(draggingTimeout.current);\n onDrop(event);\n setOver(false);\n setDragging(false);\n },\n onDragOver(event) {\n event.preventDefault();\n event.stopPropagation();\n\n window.clearTimeout(draggingTimeout.current);\n onDragOver(event);\n setOver(true);\n },\n onDragEnter(event) {\n event.preventDefault();\n event.stopPropagation();\n\n onDragEnter(event);\n setOver(true);\n },\n onDragLeave(event) {\n event.preventDefault();\n event.stopPropagation();\n\n onDragLeave(event);\n setOver(false);\n },\n },\n };\n}\n"],"names":["useEffect","useRef","useState","noop","useDropzone","options","onDrop","onDragOver","onDragEnter","onDragLeave","disableDragging","isOver","setOver","isDragging","setDragging","draggingTimeout","startDragging","handler","window","clearTimeout","current","setTimeout","addEventListener","removeEventListener","dropzoneHandlers","event","preventDefault","stopPropagation"],"mappings":"AAAA;AAEA,SAASA,SAAS,EAAEC,MAAM,EAAEC,QAAQ,QAAQ,QAAQ;AAEpD,MAAMC,OAAO;AACX,aAAa;AACf;AA2DA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAwEC,GACD,OAAO,SAASC,YAAYC,OAAwB;IAClD,MAAM,EACJC,MAAM,EACNC,aAAaJ,IAAI,EACjBK,cAAcL,IAAI,EAClBM,cAAcN,IAAI,EAClBO,kBAAkB,KAAK,EACxB,GAAGL;IAEJ,MAAM,CAACM,QAAQC,QAAQ,GAAGV,SAAS;IACnC,MAAM,CAACW,YAAYC,YAAY,GAAGZ,SAAS;IAC3C,MAAMa,kBAAkBd;IAExBD,UAAU;QACR,IAAIU,iBAAiB;YACnB;QACF;QAEA,MAAMM,gBAAgB;YACpBF,YAAY;QACd;QAEA,oEAAoE;QACpE,yEAAyE;QACzE,wEAAwE;QACxE,yEAAyE;QACzE,EAAE;QACF,yBAAyB;QACzB,MAAMG,UAAU;YACdC,OAAOC,YAAY,CAACJ,gBAAgBK,OAAO;YAC3CL,gBAAgBK,OAAO,GAAGF,OAAOG,UAAU,CAAC;gBAC1CP,YAAY;YACd,GAAG;QACL;QAEAI,OAAOI,gBAAgB,CAAC,aAAaN;QACrCE,OAAOI,gBAAgB,CAAC,YAAYL;QACpC,OAAO;YACLC,OAAOC,YAAY,CAACJ,gBAAgBK,OAAO;YAC3CF,OAAOK,mBAAmB,CAAC,aAAaP;YACxCE,OAAOK,mBAAmB,CAAC,YAAYN;QACzC;IACF,GAAG;QAACP;KAAgB;IAEpB,OAAO;QACLC;QACAE;QACAW,kBAAkB;YAChB,mDAAmD;YACnD,sEAAsE;YACtE,uEAAuE;YACvE,iBAAiB;YACjB,EAAE;YACF,iEAAiE;YACjE,mDAAmD;YACnDlB,QAAOmB,KAAK;gBACVA,MAAMC,cAAc;gBACpBD,MAAME,eAAe;gBAErBT,OAAOC,YAAY,CAACJ,gBAAgBK,OAAO;gBAC3Cd,OAAOmB;gBACPb,QAAQ;gBACRE,YAAY;YACd;YACAP,YAAWkB,KAAK;gBACdA,MAAMC,cAAc;gBACpBD,MAAME,eAAe;gBAErBT,OAAOC,YAAY,CAACJ,gBAAgBK,OAAO;gBAC3Cb,WAAWkB;gBACXb,QAAQ;YACV;YACAJ,aAAYiB,KAAK;gBACfA,MAAMC,cAAc;gBACpBD,MAAME,eAAe;gBAErBnB,YAAYiB;gBACZb,QAAQ;YACV;YACAH,aAAYgB,KAAK;gBACfA,MAAMC,cAAc;gBACpBD,MAAME,eAAe;gBAErBlB,YAAYgB;gBACZb,QAAQ;YACV;QACF;IACF;AACF"}
@@ -0,0 +1,53 @@
1
+ "use client";
2
+ import { useCallback, useState } from "react";
3
+ import { useResizeObserver } from "./useResizeObserver.js";
4
+ /**
5
+ * A small wrapper around the {@link useResizeObserver} hook to calculate the
6
+ * element's size.
7
+ *
8
+ * @example
9
+ * Simple Example
10
+ * ```tsx
11
+ * import { useElementSize } from "@react-md/core";
12
+ * import { type ReactElement } from "react";
13
+ *
14
+ * function Example(): ReactElement {
15
+ * const { height, width, elementRef } = useElementSize();
16
+ *
17
+ * return (
18
+ * <div ref={elementRef}>
19
+ * {`height: ${height}, width: ${width}`}
20
+ * </div>
21
+ * );
22
+ * }
23
+ * ```
24
+ *
25
+ * @remarks \@since 6.0.0
26
+ */ export function useElementSize(options = {}) {
27
+ const { defaultValue } = options;
28
+ const [size, setSize] = useState(()=>{
29
+ if (typeof defaultValue === "function") {
30
+ return defaultValue();
31
+ }
32
+ return defaultValue ?? {
33
+ height: 0,
34
+ width: 0
35
+ };
36
+ });
37
+ const elementRef = useResizeObserver({
38
+ ...options,
39
+ onUpdate: useCallback((entry)=>{
40
+ const size = entry.borderBoxSize[0];
41
+ setSize({
42
+ height: size.blockSize,
43
+ width: size.inlineSize
44
+ });
45
+ }, [])
46
+ });
47
+ return {
48
+ ...size,
49
+ elementRef
50
+ };
51
+ }
52
+
53
+ //# sourceMappingURL=useElementSize.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useElementSize.ts"],"sourcesContent":["\"use client\";\nimport { useCallback, useState, type RefCallback } from \"react\";\nimport { type ElementSize, type UseStateInitializer } from \"./types.js\";\nimport {\n useResizeObserver,\n type ResizeObserverHookOptions,\n} from \"./useResizeObserver.js\";\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface ElementSizeOptions<E extends HTMLElement>\n extends Omit<ResizeObserverHookOptions<E>, \"onUpdate\"> {\n /** @defaultValue `{ height: 0, width: 0 }` */\n defaultValue?: UseStateInitializer<ElementSize>;\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface ElementSizeImplementation<E extends HTMLElement>\n extends ElementSize {\n elementRef: RefCallback<E>;\n}\n\n/**\n * A small wrapper around the {@link useResizeObserver} hook to calculate the\n * element's size.\n *\n * @example\n * Simple Example\n * ```tsx\n * import { useElementSize } from \"@react-md/core\";\n * import { type ReactElement } from \"react\";\n *\n * function Example(): ReactElement {\n * const { height, width, elementRef } = useElementSize();\n *\n * return (\n * <div ref={elementRef}>\n * {`height: ${height}, width: ${width}`}\n * </div>\n * );\n * }\n * ```\n *\n * @remarks \\@since 6.0.0\n */\nexport function useElementSize<E extends HTMLElement>(\n options: ElementSizeOptions<E> = {}\n): ElementSizeImplementation<E> {\n const { defaultValue } = options;\n\n const [size, setSize] = useState<ElementSize>(() => {\n if (typeof defaultValue === \"function\") {\n return defaultValue();\n }\n\n return (\n defaultValue ?? {\n height: 0,\n width: 0,\n }\n );\n });\n\n const elementRef = useResizeObserver({\n ...options,\n onUpdate: useCallback((entry) => {\n const size = entry.borderBoxSize[0];\n\n setSize({\n height: size.blockSize,\n width: size.inlineSize,\n });\n }, []),\n });\n\n return {\n ...size,\n elementRef,\n };\n}\n"],"names":["useCallback","useState","useResizeObserver","useElementSize","options","defaultValue","size","setSize","height","width","elementRef","onUpdate","entry","borderBoxSize","blockSize","inlineSize"],"mappings":"AAAA;AACA,SAASA,WAAW,EAAEC,QAAQ,QAA0B,QAAQ;AAEhE,SACEC,iBAAiB,QAEZ,yBAAyB;AAmBhC;;;;;;;;;;;;;;;;;;;;;;CAsBC,GACD,OAAO,SAASC,eACdC,UAAiC,CAAC,CAAC;IAEnC,MAAM,EAAEC,YAAY,EAAE,GAAGD;IAEzB,MAAM,CAACE,MAAMC,QAAQ,GAAGN,SAAsB;QAC5C,IAAI,OAAOI,iBAAiB,YAAY;YACtC,OAAOA;QACT;QAEA,OACEA,gBAAgB;YACdG,QAAQ;YACRC,OAAO;QACT;IAEJ;IAEA,MAAMC,aAAaR,kBAAkB;QACnC,GAAGE,OAAO;QACVO,UAAUX,YAAY,CAACY;YACrB,MAAMN,OAAOM,MAAMC,aAAa,CAAC,EAAE;YAEnCN,QAAQ;gBACNC,QAAQF,KAAKQ,SAAS;gBACtBL,OAAOH,KAAKS,UAAU;YACxB;QACF,GAAG,EAAE;IACP;IAEA,OAAO;QACL,GAAGT,IAAI;QACPI;IACF;AACF"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useEnsuredId.ts"],"sourcesContent":["import { useId } from \"react\";\n\n/**\n * This hook is used to ensure that an `id` has been provided to a component\n * either through props or use the `useId` hook.\n *\n * @example\n * Simple Example\n * ```tsx\n * import type { HTMLAttributes, ReactElement } from \"react\";\n * import { useEnsuredId } from \"@react-md/core\";\n *\n * export function MaterialDesignComponent(props: HTMLAttributes<HTMLDivElement>): ReactElement {\n * const id = useEnsuredId(props.id, \"component-name\");\n *\n * return <div {...props} id={id} />;\n * }\n * ```\n *\n * @remarks \\@since 6.0.0\n * @internal\n */\nexport function useEnsuredId(\n propId: string | undefined,\n prefix: string\n): string {\n const id = useId();\n\n return propId ?? `${prefix}-${id}`;\n}\n"],"names":["useId","useEnsuredId","propId","prefix","id"],"mappings":"AAAA,SAASA,KAAK,QAAQ,QAAQ;AAE9B;;;;;;;;;;;;;;;;;;;CAmBC,GACD,OAAO,SAASC,aACdC,MAA0B,EAC1BC,MAAc;IAEd,MAAMC,KAAKJ;IAEX,OAAOE,UAAU,CAAC,EAAEC,OAAO,CAAC,EAAEC,GAAG,CAAC;AACpC"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useEnsuredRef.ts"],"sourcesContent":["\"use client\";\nimport type { MutableRefObject, Ref, RefCallback } from \"react\";\nimport { useCallback, useRef } from \"react\";\nimport { applyRef } from \"./utils/applyRef.js\";\n\n/**\n * @remarks \\@since 2.3.0\n * @internal\n */\nexport type EnsuredRefs<E extends HTMLElement> = readonly [\n MutableRefObject<E | null>,\n RefCallback<E | null>,\n];\n\n/**\n * This is mostly an internal hook that allows for an optional ref (normally\n * from props or hook options) to be merged with a hook's required `ref`. This\n * will return a MutableRefObject used for DOM manipulation in a custom hook\n * followed by a ref callback function that should be passed to the DOM node\n * that will ensure that both the optional `propRef` and hook ref are updated.\n *\n * @example\n * Simple Example\n * ```tsx\n * import { HTMLAttributes, forwardRef } from \"react\";\n * import { useEnsuredRef } from \"@react-md/core\";\n *\n * export type ExampleProps = HTMLAttributes<HTMLDivElement>;\n *\n * export const Example = forwardRef<HTMLDivElement, ExampleProps>(function Example(props, ref) {\n * const [nodeRef, refHandler] = useEnsuredRef(ref);\n * useEffect(() => {\n * // do something with nodeRef.current\n * }, [nodeRef])\n *\n * return <div ref={refHandler} />;\n * });\n * ```\n *\n * @remarks \\@since 2.3.0\n * @internal\n */\nexport function useEnsuredRef<E extends HTMLElement>(\n propRef?: Ref<E | null>\n): EnsuredRefs<E> {\n const ref = useRef<E | null>(null);\n const refHandler = useCallback(\n (instance: E | null) => {\n applyRef(instance, propRef);\n ref.current = instance;\n },\n [propRef]\n );\n\n return [ref, refHandler];\n}\n"],"names":["useCallback","useRef","applyRef","useEnsuredRef","propRef","ref","refHandler","instance","current"],"mappings":"AAAA;AAEA,SAASA,WAAW,EAAEC,MAAM,QAAQ,QAAQ;AAC5C,SAASC,QAAQ,QAAQ,sBAAsB;AAW/C;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2BC,GACD,OAAO,SAASC,cACdC,OAAuB;IAEvB,MAAMC,MAAMJ,OAAiB;IAC7B,MAAMK,aAAaN,YACjB,CAACO;QACCL,SAASK,UAAUH;QACnBC,IAAIG,OAAO,GAAGD;IAChB,GACA;QAACH;KAAQ;IAGX,OAAO;QAACC;QAAKC;KAAW;AAC1B"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useEnsuredState.ts"],"sourcesContent":["/* eslint-disable react-hooks/rules-of-hooks */\nimport type { Dispatch } from \"react\";\nimport { useState } from \"react\";\nimport type { UseStateInitializer, UseStateSetter } from \"./types.js\";\n\n/**\n * @internal\n * @remarks \\@since 6.0.0\n */\nexport interface EnsuredStateOptions<\n V,\n Setter extends Dispatch<V> | UseStateSetter<V>,\n> {\n value?: V;\n setValue?: Setter;\n defaultValue?: UseStateInitializer<V>;\n}\n\n/**\n * This is used to dynamically allow controlling hooks by providing a `value` +\n * `setValue` or defaulting to uncontrolled behavior with local state.\n *\n * @internal\n * @remarks \\@since 6.0.0\n */\nexport function useEnsuredState<\n V,\n Setter extends Dispatch<V> | UseStateSetter<V>,\n>(\n options: EnsuredStateOptions<V, Setter>\n): readonly [value: V, setValue: Setter] {\n const { value, setValue, defaultValue } = options;\n if (typeof value !== \"undefined\" && typeof setValue !== \"undefined\") {\n return [value, setValue];\n }\n\n if (typeof value !== \"undefined\" || typeof setValue !== \"undefined\") {\n throw new Error(\n \"Both a `value` and `setValue` must be defined for controlled components.\"\n );\n }\n\n if (typeof defaultValue === \"undefined\") {\n throw new Error(\n \"A `defaultValue` must be defined for uncontrolled components.\"\n );\n }\n\n return useState(defaultValue) as [value: V, setValue: Setter];\n}\n"],"names":["useState","useEnsuredState","options","value","setValue","defaultValue","Error"],"mappings":"AAAA,6CAA6C,GAE7C,SAASA,QAAQ,QAAQ,QAAQ;AAgBjC;;;;;;CAMC,GACD,OAAO,SAASC,gBAIdC,OAAuC;IAEvC,MAAM,EAAEC,KAAK,EAAEC,QAAQ,EAAEC,YAAY,EAAE,GAAGH;IAC1C,IAAI,OAAOC,UAAU,eAAe,OAAOC,aAAa,aAAa;QACnE,OAAO;YAACD;YAAOC;SAAS;IAC1B;IAEA,IAAI,OAAOD,UAAU,eAAe,OAAOC,aAAa,aAAa;QACnE,MAAM,IAAIE,MACR;IAEJ;IAEA,IAAI,OAAOD,iBAAiB,aAAa;QACvC,MAAM,IAAIC,MACR;IAEJ;IAEA,OAAON,SAASK;AAClB"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useHtmlClassName.ts"],"sourcesContent":["\"use client\";\nimport { useEffect } from \"react\";\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport function useHtmlClassName(className: string): void {\n useEffect(() => {\n if (!className) {\n return;\n }\n\n const html = document.documentElement;\n html.classList.add(className);\n return () => {\n html.classList.remove(className);\n };\n }, [className]);\n}\n"],"names":["useEffect","useHtmlClassName","className","html","document","documentElement","classList","add","remove"],"mappings":"AAAA;AACA,SAASA,SAAS,QAAQ,QAAQ;AAElC;;CAEC,GACD,OAAO,SAASC,iBAAiBC,SAAiB;IAChDF,UAAU;QACR,IAAI,CAACE,WAAW;YACd;QACF;QAEA,MAAMC,OAAOC,SAASC,eAAe;QACrCF,KAAKG,SAAS,CAACC,GAAG,CAACL;QACnB,OAAO;YACLC,KAAKG,SAAS,CAACE,MAAM,CAACN;QACxB;IACF,GAAG;QAACA;KAAU;AAChB"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useIntersectionObserver.ts"],"sourcesContent":["\"use client\";\nimport type { Ref, RefCallback, RefObject } from \"react\";\nimport { useEffect } from \"react\";\nimport { useEnsuredRef } from \"./useEnsuredRef.js\";\n\n/** @remarks \\@since 6.0.0 */\nexport type IntersectionObserverRoot = IntersectionObserverInit[\"root\"];\n/** @remarks \\@since 6.0.0 */\nexport type IntersectionObserverThreshold =\n IntersectionObserverInit[\"threshold\"];\n/** @remarks \\@since 6.0.0 */\nexport type IntersectionObserverRootMargin =\n IntersectionObserverInit[\"rootMargin\"];\n\n/**\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API#intersection_observer_options}\n * @remarks \\@since 6.0.0\n */\nexport interface BaseIntersectionObserverHookOptions {\n /**\n * This is the same as the normal `root` for an IntersectionObserverInit, but\n * also supports refs.\n */\n root?: RefObject<IntersectionObserverRoot> | IntersectionObserverRoot;\n\n /**\n * Set this to `true` if the intersection observer behavior should be\n * disabled.\n *\n * @defaultValue `false`\n */\n disabled?: boolean;\n\n /**\n * **When using a list of thresholds, they must either be defined outside of\n * the component or wrapped in a `useMemo` to prevent the IntersectionObserver\n * from being re-created each render.**\n *\n * @example\n * Moving Out of Render\n * ```tsx\n * const threshold = [0, 0.25, 0.5, 0.75, 1];\n *\n * function Example() {\n * const targetRef = useIntersectionObserver({\n * threshold,\n * onUpdate: useCallback(([entry]) => {\n * // do something\n * }, []),\n * })\n * }\n * ```\n *\n * @example\n * Wrapping in useMemo\n * ```tsx\n * interface ExampleProps {\n * min: number;\n * max: number;\n * }\n *\n * function Example({ min, max }: ExampleProps): ReactElement {\n * const targetRef = useIntersectionObserver({\n * threshold: useMemo(() => [min, max], [min, max]),\n * onUpdate: useCallback(([entry]) => {\n * // do something\n * }, []),\n * });\n * }\n * ```\n *\n * @see {@link getThreshold}\n */\n threshold?: IntersectionObserverThreshold;\n\n /** @see {@link getRootMargin} */\n rootMargin?: IntersectionObserverRootMargin;\n\n /**\n * **Must be wrapped in `useCallback` to prevent re-creating the\n * IntersectionObserver each render.**\n *\n * This can be used to dynamically generate the {@link threshold} which is\n * generally useful if you need access to the DOM or do some expensive\n * computation.\n *\n * @example\n * Simple Example\n * ```tsx\n * const targetRef = useIntersectionObserver({\n * getThreshold: useCallback(() => {\n * // pretend some expensive computation\n * return [0, 0.25, 0.5, 0.75, 1];\n * }, []),\n * OnUpdate: useCallback(() => {\n * // do something\n * }, []),\n * });\n * ```\n *\n * If this option is provided, {@link threshold}'s value will be ignored.\n */\n getThreshold?(): IntersectionObserverThreshold;\n\n /**\n * **Must be wrapped in `useCallback` to prevent re-creating the\n * IntersectionObserver each render.**\n *\n * This can be used to dynamically generate the {@link rootMargin} which is\n * generally useful if you need access to the DOM.\n *\n * @example\n * Simple Example\n * ```tsx\n * const nodeRef = useRef<HTMLElement>();\n * const targetRef = useIntersectionObserver({\n * getRootMargin: useCallback(() => {\n * return `-${nodeRef.current.offsetHeight - 1}px 0px 0px`;\n * }, []),\n * onUpdate: useCallback(() => {\n * // do something\n * }, []),\n * });\n * ```\n *\n * Note: If this option is provided, {@link rootMargin} will be ignored.\n */\n getRootMargin?(): IntersectionObserverRootMargin;\n}\n\n/**\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API#intersection_observer_options}\n * @remarks \\@since 6.0.0\n */\nexport interface IntersectionObserverHookOptions<E extends HTMLElement>\n extends BaseIntersectionObserverHookOptions {\n /**\n * An optional ref to merge with the ref returned by this hook.\n */\n ref?: Ref<E>;\n\n /**\n * **Must be wrapped in `useCallback` to prevent re-creating the\n * IntersectionObserver each render.**\n *\n * @example\n * Simple Example\n * ```tsx\n * const threshold = [0, 0.25, 0.5, 0.75, 1];\n *\n * function Example(): ReactElement {\n * const [intersecting, setIntersecting] = useState(false);\n * const targetRef = useIntersectionObserver({\n * threshold,\n * onUpdate: useCallback(([entry]) {\n * setIntersecting(entry.isIntersecting);\n * }, []),\n * });\n *\n * // implementation\n * }\n * ```\n */\n onUpdate(entries: readonly IntersectionObserverEntry[]): void;\n\n /**\n * **Must be wrapped in `useCallback` to prevent re-creating the\n * IntersectionObserver each render.**\n *\n * If this is defined, the {@link ref} will be ignored along with the returned\n * ref.\n *\n * @example\n * Watching Queried Elements\n * ```tsx\n * function Example(): ReactElement {\n * useIntersectionObserver({\n * onUpdate: useCallback((entries) => {\n * entries.forEach((entry) => {\n * // do stuff\n * });\n *\n * setIntersectingIds(intersecting);\n * }, []),\n * getTargets: useCallback(() => {\n * return document.querySelectorAll('h1, h2, h3, h4, h5, h6');\n * }, []),\n * }),\n *\n * return <div {...props} />;\n * }\n * ```\n */\n getTargets?(): readonly Element[];\n}\n\n/**\n * @example\n * Simple Example\n * ```tsx\n * // https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API#a_simple_example\n *\n * import { useIntersectionObserver } from \"@react-md/core\";\n * import type { ReactElement } from \"react\";\n * import { useState } from \"react\";\n *\n * import styles from \"./Example.module.scss\";\n *\n * const numSteps = 20;\n * const thresholds = Array.from({ length: numSteps }, (_, i) => i / numSteps);\n * thresholds.push(0);\n *\n * const INCREASING = \"rgba(40, 40, 190, ratio)\";\n * const DECREASING = \"rgba(190, 40, 40, ratio)\";\n *\n * export default function Example(): ReactElement {\n * const [{ ratio, increasing }, setState] = useState({\n * ratio: 0.0,\n * increasing: true,\n * });\n *\n * const targetRef = useIntersectionObserver({\n * threshold: thresholds,\n * rootMargin: \"0px\",\n * onUpdate: useCallback(([entry]) => {\n * const { intersectionRatio } = entry;\n * setState((prevState) => {\n * return {\n * ratio: intersectionRatio,\n * increasing: intersectionRatio > prevState.ratio,\n * };\n * });\n * }, []),\n * });\n *\n * return (\n * <div\n * ref={targetRef}\n * className={styles.box}\n * style={{\n * backgroundColor: (increasing ? INCREASING : DECREASING).replace(\n * \"ratio\",\n * `${ratio}`\n * ),\n * }}\n * >\n * <div className={styles.vertical}>\n * Welcome to <strong>The Box!</strong>\n * </div>\n * </div>\n * );\n * }\n * ```\n *\n * @remarks \\@since 6.0.0\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API\n */\nexport function useIntersectionObserver<E extends HTMLElement>(\n options: IntersectionObserverHookOptions<E>\n): RefCallback<E> {\n const {\n ref,\n root,\n disabled = false,\n onUpdate,\n threshold,\n rootMargin,\n getTargets,\n getThreshold,\n getRootMargin,\n } = options;\n\n const [targetNodeRef, targetRef] = useEnsuredRef(ref);\n\n useEffect(() => {\n const element = targetNodeRef.current;\n let targets: readonly Element[] = [];\n if (getTargets) {\n targets = getTargets();\n } else if (element) {\n targets = [element];\n }\n\n if (disabled || !targets.length) {\n return;\n }\n\n let resolvedRoot: IntersectionObserverRoot;\n if (root && \"current\" in root) {\n resolvedRoot = root.current;\n } else {\n resolvedRoot = root;\n }\n\n const options: IntersectionObserverInit = {\n root: resolvedRoot,\n threshold: (getThreshold || (() => threshold))(),\n rootMargin: (getRootMargin || (() => rootMargin))(),\n };\n\n // Just like the ResizeObserver, you can see performance improvements by\n // sharing a single intersection observer but I don't think it's worth the\n // effort to implement here since I'd need to:\n // - check if there is an observer with the same options\n // - if there is, add the callback to that existing observer\n // - if there isn't, create a new observer\n // - when cleaning up, check if there are any other existing callbacks\n // - disconnect and remove the observer if there are none left\n const observer = new IntersectionObserver(onUpdate, options);\n targets.forEach((target) => {\n observer.observe(target);\n });\n\n return () => {\n observer.disconnect();\n };\n }, [\n disabled,\n getRootMargin,\n getTargets,\n getThreshold,\n onUpdate,\n root,\n rootMargin,\n targetNodeRef,\n threshold,\n ]);\n\n return targetRef;\n}\n"],"names":["useEffect","useEnsuredRef","useIntersectionObserver","options","ref","root","disabled","onUpdate","threshold","rootMargin","getTargets","getThreshold","getRootMargin","targetNodeRef","targetRef","element","current","targets","length","resolvedRoot","observer","IntersectionObserver","forEach","target","observe","disconnect"],"mappings":"AAAA;AAEA,SAASA,SAAS,QAAQ,QAAQ;AAClC,SAASC,aAAa,QAAQ,qBAAqB;AAiMnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4DC,GACD,OAAO,SAASC,wBACdC,OAA2C;IAE3C,MAAM,EACJC,GAAG,EACHC,IAAI,EACJC,WAAW,KAAK,EAChBC,QAAQ,EACRC,SAAS,EACTC,UAAU,EACVC,UAAU,EACVC,YAAY,EACZC,aAAa,EACd,GAAGT;IAEJ,MAAM,CAACU,eAAeC,UAAU,GAAGb,cAAcG;IAEjDJ,UAAU;QACR,MAAMe,UAAUF,cAAcG,OAAO;QACrC,IAAIC,UAA8B,EAAE;QACpC,IAAIP,YAAY;YACdO,UAAUP;QACZ,OAAO,IAAIK,SAAS;YAClBE,UAAU;gBAACF;aAAQ;QACrB;QAEA,IAAIT,YAAY,CAACW,QAAQC,MAAM,EAAE;YAC/B;QACF;QAEA,IAAIC;QACJ,IAAId,QAAQ,aAAaA,MAAM;YAC7Bc,eAAed,KAAKW,OAAO;QAC7B,OAAO;YACLG,eAAed;QACjB;QAEA,MAAMF,UAAoC;YACxCE,MAAMc;YACNX,WAAW,AAACG,CAAAA,gBAAiB,CAAA,IAAMH,SAAQ,CAAC;YAC5CC,YAAY,AAACG,CAAAA,iBAAkB,CAAA,IAAMH,UAAS,CAAC;QACjD;QAEA,wEAAwE;QACxE,0EAA0E;QAC1E,8CAA8C;QAC9C,wDAAwD;QACxD,8DAA8D;QAC9D,4CAA4C;QAC5C,sEAAsE;QACtE,gEAAgE;QAChE,MAAMW,WAAW,IAAIC,qBAAqBd,UAAUJ;QACpDc,QAAQK,OAAO,CAAC,CAACC;YACfH,SAASI,OAAO,CAACD;QACnB;QAEA,OAAO;YACLH,SAASK,UAAU;QACrB;IACF,GAAG;QACDnB;QACAM;QACAF;QACAC;QACAJ;QACAF;QACAI;QACAI;QACAL;KACD;IAED,OAAOM;AACT"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useIsomorphicLayoutEffect.ts"],"sourcesContent":["\"use client\";\nimport { useEffect, useLayoutEffect } from \"react\";\n\n/**\n * This is copy/pasted from react-redux which has some more information about\n * this and how to fix \"invalid\" warnings while running tests.\n *\n * @see {@link https://github.com/reduxjs/react-redux/blob/4c907c0870c6b9a136dd69be294c17d1dc63c8f5/src/utils/useIsomorphicLayoutEffect.js}\n */\nexport const useIsomorphicLayoutEffect =\n typeof window !== \"undefined\" &&\n typeof window.document !== \"undefined\" &&\n typeof window.document.createElement !== \"undefined\"\n ? useLayoutEffect\n : useEffect;\n"],"names":["useEffect","useLayoutEffect","useIsomorphicLayoutEffect","window","document","createElement"],"mappings":"AAAA;AACA,SAASA,SAAS,EAAEC,eAAe,QAAQ,QAAQ;AAEnD;;;;;CAKC,GACD,OAAO,MAAMC,4BACX,OAAOC,WAAW,eAClB,OAAOA,OAAOC,QAAQ,KAAK,eAC3B,OAAOD,OAAOC,QAAQ,CAACC,aAAa,KAAK,cACrCJ,kBACAD,UAAU"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useLocalStorage.ts"],"sourcesContent":["\"use client\";\nimport { useCallback, useEffect, useRef, useState } from \"react\";\nimport { useSsr } from \"./SsrProvider.js\";\nimport type { UseStateInitializer, UseStateSetter } from \"./types.js\";\nimport { useIsomorphicLayoutEffect } from \"./useIsomorphicLayoutEffect.js\";\nimport { identity } from \"./utils/identity.js\";\n\n/** @remarks \\@since 6.0.0 */\nexport type LocalStorageSerializer<T> = (value: T) => string;\n/** @remarks \\@since 6.0.0 */\nexport type LocalStorageDeserializer<T> = (item: string) => T;\n\n/** @remarks \\@since 6.0.0 */\nexport interface LocalStorageHookOptions<T> {\n /**\n * The local storage key name to use.\n *\n * This can be set to an empty string for internal usage of conditionally\n * saving items to local storage.\n */\n key: string;\n\n /**\n * The default value to use if an item does not exist in local storage.\n */\n defaultValue: UseStateInitializer<T>;\n\n /**\n * Set this to `true` if the `value` should not persist to local storage\n * immediately whenever it changes. You will manually need to call\n * {@link LocalStorageHookReturnValue.persist} instead.\n *\n * @see {@link LocalStorageHookReturnValue.persist} for an example.\n * @defaultValue `false`\n */\n manual?: boolean;\n\n /**\n * Set this to `true` to update:\n *\n * - the default {@link serializer} to be:\n * ```\n * typeof value === \"string\" ? value : `${value}`\n * ```\n * - the default {@link deserializer} to not call `JSON.parse` if the\n * {@link defaultValue} is a string.\n *\n * @defaultValue `typeof defaultValue === 'string'`\n */\n raw?: boolean;\n\n /**\n * An optional function to serialize the `value` before storing it in local\n * storage.\n *\n * @defaultValue `JSON.stringify`\n */\n serializer?: LocalStorageSerializer<T>;\n\n /**\n * An optional function to deserialize the `value` if the item existed in\n * local storage.\n *\n * @defaultValue `JSON.parse`\n */\n deserializer?: LocalStorageDeserializer<T>;\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport const defaultLocalStorageSerializer = <T>(value: T): string =>\n typeof value === \"string\" ? value : `${value}`;\n\n/** @remarks \\@since 6.0.0 */\nexport interface GetItemFromStorageOptions<T> {\n /**\n * The storage key to use\n */\n key: string;\n\n /**\n * A value to use when the {@link key} does not exist in storage or there is\n * an error deserializing the value.\n */\n fallback: T;\n\n /** @see {@link LocalStorageHookOptions.deserializer} */\n deserializer?: LocalStorageDeserializer<T>;\n\n /** @defaultValue `localStorage` */\n storage?: Storage;\n}\n\n/**\n * You'll most likely want to use {@link useLocalStorage} instead, but this is a\n * low-level util to \"safely\" get an item from local storage.\n *\n * @example\n * ```ts\n * import { getItemFromStorage } from \"@react-md/core\";\n *\n * const values = [\"a\", \"b\", \"c\", \"d\"] as const;\n *\n * const item1 = getItemFromStorage({\n * key: \"testKey\",\n * fallback: values[0],\n * deserializer(item) {\n * if (!values.includes(item)) {\n * return values[0]\n * }\n *\n * return item;\n * },\n * });\n *\n * const item2 = getItemFromStorage({\n * key: \"anotherKey\",\n * fallback: -1,\n * });\n *\n * const item3 = getItemFromStorage({\n * key: \"anotherKey\",\n * fallback: -1,\n * storage: sessionStorage,\n * });\n * ```\n *\n * @remarks \\@since 6.0.0\n */\nexport const getItemFromStorage = <T>(\n options: GetItemFromStorageOptions<T>\n): T => {\n const {\n key,\n fallback,\n storage = localStorage,\n deserializer = JSON.parse,\n } = options;\n if (!key) {\n return fallback;\n }\n\n try {\n const value = storage.getItem(key);\n return !value ? fallback : deserializer(value);\n } catch (e) {\n return fallback;\n }\n};\n\n/** @remarks \\@since 6.0.0 */\nexport interface SetItemInStorageOptions<T> {\n key: string;\n value: T;\n /** @defaultValue `localStorage` */\n storage?: Storage;\n\n /** @see {@link LocalStorageHookOptions.serializer} */\n serializer?: LocalStorageSerializer<T>;\n}\n\n/**\n * You'll most likely want to use {@link useLocalStorage} instead, but this is a\n * low-level util to \"safely\" get an item from local storage.\n *\n * @example\n * ```ts\n * import { identity, getItemFromStorage } from \"@react-md/core\";\n *\n * const values = [\"a\", \"b\", \"c\", \"d\"] as const;\n *\n * setItemInStorage({\n * key: \"testKey\",\n * value: values[0],\n * // store string value as-is\n * serializer: identity,\n * });\n *\n * setItemInStorage({\n * key: \"anotherKey\",\n * value: 100,\n * });\n *\n * setItemInStorage({\n * key: \"anotherKey\",\n * value: 100,\n * storage: sessionStorage,\n * });\n * ```\n *\n * @remarks \\@since 6.0.0\n */\nexport const setItemInStorage = <T>(\n options: SetItemInStorageOptions<T>\n): void => {\n const {\n key,\n value,\n storage = localStorage,\n serializer = JSON.stringify,\n } = options;\n if (!key) {\n return;\n }\n\n try {\n storage.setItem(key, serializer(value));\n } catch {\n //\n }\n};\n\n/**\n * @remarks \\@since 6.0.0\n * @internal\n */\ninterface RemoveItemFromStorageOptions {\n key: string;\n\n /** @defaultValue `localStorage` */\n storage?: Storage;\n}\n\n/**\n * @remarks \\@since 6.0.0\n * @internal\n */\nexport const removeItemFromStorage = (\n options: RemoveItemFromStorageOptions\n): void => {\n const { key, storage = localStorage } = options;\n if (!key) {\n return;\n }\n\n try {\n storage.removeItem(key);\n } catch {\n // do nothing\n }\n};\n\n/** @remarks \\@since 6.0.0 */\nexport interface LocalStorageHookReturnValue<T> {\n value: T;\n\n /**\n * Updates the {@link value} in state. When the\n * {@link LocalStorageHookOptions.manual} option is `false`, the value will\n * also be updated in local storage immediately.\n */\n setValue: UseStateSetter<T>;\n\n /**\n * Remove the item from local storage.\n */\n remove(): void;\n\n /**\n * Manually persist the current {@link value} into local storage. This is only\n * useful if the {@link LocalStorageHookOptions.manual} option is `true`.\n *\n * @example\n * Manual Persisting\n * ```tsx\n * import type { ReactElement } from \"react\";\n *\n * function Example(): ReactElement {\n * const { value, setValue, persist } = useLocalStorage({\n * key: \"someKey\",\n * manual: true,\n * defaultValue: \"\",\n * });\n *\n * return (\n * <>\n * <Button onClick={closeDialog}>\n * Cancel\n * </Button>\n * <Button\n * onClick={async () => {\n * await saveToDatabase(value);\n * persist();\n * closeDialog();\n * }}\n * >\n * Confirm\n * </Button>\n * </>\n * );\n * }\n * ```\n */\n persist(): void;\n}\n\n/**\n * @example\n * Simple Example\n * ```tsx\n * import type { ReactElement } from \"react\";\n * import { TextField, useLocalStorage } from \"@react-md/core\";\n *\n * function Example(): ReactElement {\n * const { value, setValue } = useLocalStorage({\n * key: \"savedSearch\",\n * defaultValue: \"\",\n * });\n *\n * return (\n * <TextField\n * label=\"Search\"\n * placeholder=\"Search...\"\n * type=\"search\"\n * value={value}\n * onChange={(event) => {\n * setValue(event.currentTarget.value)\n * }}\n * />\n * );\n * }\n * ```\n *\n * @example\n * Type-safe Objects\n * ```tsx\n * import type { ReactElement } from \"react\";\n * import { useLocalStorage } from \"@react-md/core\";\n *\n * interface ExpectedSchema {\n * label: string;\n * value: string;\n * // others\n * }\n *\n * function Example(): ReactElement {\n * const { value, setValue } = useLocalStorage<ExpectedSchema | null>({\n * key: \"someKey\",\n * defaultValue: null,\n *\n * // this is optional: you can create a custom deserializer to validate\n * // the stored value to prevent people manually updating local storage in\n * // the dev tools\n * deserializer(item) {\n * const parsed = JSON.parse(item):\n * const { label, value } = parsed;\n * if (typeof label !== 'string' || typeof value !== 'string') {\n * return null;\n * }\n *\n * return { label, value };\n * }\n * });\n *\n * // do something\n * // value will be `ExpectedSchema | null`\n * }\n * ```\n *\n * @example\n * Manual Persistence\n * ```tsx\n * import type { ReactElement } from \"react\";\n * import { Button, Checkbox, Form, useLocalStorage } from \"@react-md/core\";\n *\n * function Example(): ReactElement {\n * const { value, setValue, remove, persist } = useLocalStorage({\n * key: \"someKey\",\n * manual: true,\n * defaultValue: false,\n * });\n *\n * return (\n * <Form\n * onSubmit={() => {\n * // current value will be saved into local storage\n * persist();\n * }}\n * onReset={() => {\n * // \"someKey\" will be removed from local storage\n * remove();\n * }}\n * >\n * <Checkbox\n * label=\"Allow cookies\"\n * checked={value}\n * onChange={(event) =>\n * setValue(event.currentTarget.checked);\n * }\n * />\n * <Button type=\"reset\">Decline</Button>\n * <Button type=\"submit\">Save</Button>\n * </Form>\n * );\n * }\n * ```\n *\n * Note: Using the same local storage key in multiple parts in your app will not\n * update all instances with that value. The value will only be updated if it\n * was updated in a separate tab with the `\"storage\"` event. You must setup your\n * own context to share values or another state manager solution.\n *\n * @example\n * Shared Value\n * ```tsx\n * const context = createContext(null);\n * const { Provider } = context;\n *\n * export function useSomeValue(): string {\n * const value = useContext(context);\n * if (!value) {\n * throw new Error()\n * }\n *\n * return value;\n * }\n *\n * function Example({ children }: { children: ReactNode }) {\n * const { value, setValue, remove, persist } = useLocalStorage({\n * key: \"someKey\",\n * defaultValue: \"\",\n *\n * // optional\n * manual: true,\n * });\n *\n * return (\n * <Provider\n * value={useMemo(() => ({\n * value,\n * setValue,\n *\n * // remove and persist are optional\n * remove,\n * persist,\n * }), [value, setValue, remove, persist])}\n * >\n * {children}\n * </Provider>\n * );\n * }\n *\n * function SomeChildComponent() {\n * const { value, setValue } = useSomeValue();\n * // do stuff\n * }\n * ```\n *\n * @remarks \\@since 6.0.0\n */\nexport function useLocalStorage<T>(\n options: LocalStorageHookOptions<T>\n): LocalStorageHookReturnValue<T> {\n const { key, defaultValue, manual = false } = options;\n\n const [initialValue] = useState(defaultValue);\n // this allows for strings to automatically be stored as-is instead of adding\n // additional quotes around then with JSON.stringify\n const raw = options.raw ?? typeof initialValue === \"string\";\n const serializer =\n options.serializer ??\n (raw ? defaultLocalStorageSerializer : JSON.stringify);\n const deserializer =\n options.deserializer ??\n (raw && typeof initialValue === \"string\" ? identity : JSON.parse);\n\n const ssr = useSsr();\n const [value, setStoredValue] = useState<T>(() => {\n if (ssr) {\n return initialValue;\n }\n\n const value = getItemFromStorage({\n key,\n fallback: initialValue,\n deserializer,\n });\n if (!manual) {\n setItemInStorage({\n key,\n value,\n serializer,\n });\n }\n\n return value;\n });\n const config = useRef({\n key,\n value,\n manual,\n serializer,\n deserializer,\n defaultValue: initialValue,\n } as const);\n useIsomorphicLayoutEffect(() => {\n config.current = {\n key,\n value,\n manual,\n serializer,\n deserializer,\n defaultValue: initialValue,\n };\n });\n\n const setValue = useCallback<UseStateSetter<T>>((valueOrDispatcher) => {\n const { key, manual, serializer } = config.current;\n setStoredValue((prevValue) => {\n const nextValue =\n valueOrDispatcher instanceof Function\n ? valueOrDispatcher(prevValue)\n : valueOrDispatcher;\n\n if (!manual) {\n setItemInStorage({\n key,\n value: nextValue,\n serializer,\n });\n }\n\n return nextValue;\n });\n }, []);\n\n const remove = useCallback(() => {\n removeItemFromStorage({\n key: config.current.key,\n });\n }, []);\n\n const persist = useCallback(() => {\n const { key, value, serializer } = config.current;\n setItemInStorage({\n key,\n value,\n serializer,\n });\n }, []);\n\n useEffect(() => {\n const { defaultValue, deserializer, manual } = config.current;\n if (manual || !ssr) {\n return;\n }\n\n setValue(\n getItemFromStorage({\n key,\n fallback: defaultValue,\n deserializer,\n })\n );\n }, [key, ssr, setValue]);\n\n // update the value if another tab changed the local storage value\n useEffect(() => {\n if (!key) {\n return;\n }\n\n const callback = (event: StorageEvent): void => {\n const { defaultValue, deserializer } = config.current;\n if (event.key === key) {\n setStoredValue(\n getItemFromStorage({\n key,\n fallback: defaultValue,\n deserializer,\n })\n );\n }\n };\n\n window.addEventListener(\"storage\", callback);\n return () => {\n window.removeEventListener(\"storage\", callback);\n };\n }, [key]);\n\n return {\n value,\n setValue,\n remove,\n persist,\n };\n}\n"],"names":["useCallback","useEffect","useRef","useState","useSsr","useIsomorphicLayoutEffect","identity","defaultLocalStorageSerializer","value","getItemFromStorage","options","key","fallback","storage","localStorage","deserializer","JSON","parse","getItem","e","setItemInStorage","serializer","stringify","setItem","removeItemFromStorage","removeItem","useLocalStorage","defaultValue","manual","initialValue","raw","ssr","setStoredValue","config","current","setValue","valueOrDispatcher","prevValue","nextValue","Function","remove","persist","callback","event","window","addEventListener","removeEventListener"],"mappings":"AAAA;AACA,SAASA,WAAW,EAAEC,SAAS,EAAEC,MAAM,EAAEC,QAAQ,QAAQ,QAAQ;AACjE,SAASC,MAAM,QAAQ,mBAAmB;AAE1C,SAASC,yBAAyB,QAAQ,iCAAiC;AAC3E,SAASC,QAAQ,QAAQ,sBAAsB;AA+D/C;;CAEC,GACD,OAAO,MAAMC,gCAAgC,CAAIC,QAC/C,OAAOA,UAAU,WAAWA,QAAQ,CAAC,EAAEA,MAAM,CAAC,CAAC;AAsBjD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAmCC,GACD,OAAO,MAAMC,qBAAqB,CAChCC;IAEA,MAAM,EACJC,GAAG,EACHC,QAAQ,EACRC,UAAUC,YAAY,EACtBC,eAAeC,KAAKC,KAAK,EAC1B,GAAGP;IACJ,IAAI,CAACC,KAAK;QACR,OAAOC;IACT;IAEA,IAAI;QACF,MAAMJ,QAAQK,QAAQK,OAAO,CAACP;QAC9B,OAAO,CAACH,QAAQI,WAAWG,aAAaP;IAC1C,EAAE,OAAOW,GAAG;QACV,OAAOP;IACT;AACF,EAAE;AAaF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA8BC,GACD,OAAO,MAAMQ,mBAAmB,CAC9BV;IAEA,MAAM,EACJC,GAAG,EACHH,KAAK,EACLK,UAAUC,YAAY,EACtBO,aAAaL,KAAKM,SAAS,EAC5B,GAAGZ;IACJ,IAAI,CAACC,KAAK;QACR;IACF;IAEA,IAAI;QACFE,QAAQU,OAAO,CAACZ,KAAKU,WAAWb;IAClC,EAAE,OAAM;IACN,EAAE;IACJ;AACF,EAAE;AAaF;;;CAGC,GACD,OAAO,MAAMgB,wBAAwB,CACnCd;IAEA,MAAM,EAAEC,GAAG,EAAEE,UAAUC,YAAY,EAAE,GAAGJ;IACxC,IAAI,CAACC,KAAK;QACR;IACF;IAEA,IAAI;QACFE,QAAQY,UAAU,CAACd;IACrB,EAAE,OAAM;IACN,aAAa;IACf;AACF,EAAE;AAwDF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyJC,GACD,OAAO,SAASe,gBACdhB,OAAmC;IAEnC,MAAM,EAAEC,GAAG,EAAEgB,YAAY,EAAEC,SAAS,KAAK,EAAE,GAAGlB;IAE9C,MAAM,CAACmB,aAAa,GAAG1B,SAASwB;IAChC,6EAA6E;IAC7E,oDAAoD;IACpD,MAAMG,MAAMpB,QAAQoB,GAAG,IAAI,OAAOD,iBAAiB;IACnD,MAAMR,aACJX,QAAQW,UAAU,IACjBS,CAAAA,MAAMvB,gCAAgCS,KAAKM,SAAS,AAAD;IACtD,MAAMP,eACJL,QAAQK,YAAY,IACnBe,CAAAA,OAAO,OAAOD,iBAAiB,WAAWvB,WAAWU,KAAKC,KAAK,AAAD;IAEjE,MAAMc,MAAM3B;IACZ,MAAM,CAACI,OAAOwB,eAAe,GAAG7B,SAAY;QAC1C,IAAI4B,KAAK;YACP,OAAOF;QACT;QAEA,MAAMrB,QAAQC,mBAAmB;YAC/BE;YACAC,UAAUiB;YACVd;QACF;QACA,IAAI,CAACa,QAAQ;YACXR,iBAAiB;gBACfT;gBACAH;gBACAa;YACF;QACF;QAEA,OAAOb;IACT;IACA,MAAMyB,SAAS/B,OAAO;QACpBS;QACAH;QACAoB;QACAP;QACAN;QACAY,cAAcE;IAChB;IACAxB,0BAA0B;QACxB4B,OAAOC,OAAO,GAAG;YACfvB;YACAH;YACAoB;YACAP;YACAN;YACAY,cAAcE;QAChB;IACF;IAEA,MAAMM,WAAWnC,YAA+B,CAACoC;QAC/C,MAAM,EAAEzB,GAAG,EAAEiB,MAAM,EAAEP,UAAU,EAAE,GAAGY,OAAOC,OAAO;QAClDF,eAAe,CAACK;YACd,MAAMC,YACJF,6BAA6BG,WACzBH,kBAAkBC,aAClBD;YAEN,IAAI,CAACR,QAAQ;gBACXR,iBAAiB;oBACfT;oBACAH,OAAO8B;oBACPjB;gBACF;YACF;YAEA,OAAOiB;QACT;IACF,GAAG,EAAE;IAEL,MAAME,SAASxC,YAAY;QACzBwB,sBAAsB;YACpBb,KAAKsB,OAAOC,OAAO,CAACvB,GAAG;QACzB;IACF,GAAG,EAAE;IAEL,MAAM8B,UAAUzC,YAAY;QAC1B,MAAM,EAAEW,GAAG,EAAEH,KAAK,EAAEa,UAAU,EAAE,GAAGY,OAAOC,OAAO;QACjDd,iBAAiB;YACfT;YACAH;YACAa;QACF;IACF,GAAG,EAAE;IAELpB,UAAU;QACR,MAAM,EAAE0B,YAAY,EAAEZ,YAAY,EAAEa,MAAM,EAAE,GAAGK,OAAOC,OAAO;QAC7D,IAAIN,UAAU,CAACG,KAAK;YAClB;QACF;QAEAI,SACE1B,mBAAmB;YACjBE;YACAC,UAAUe;YACVZ;QACF;IAEJ,GAAG;QAACJ;QAAKoB;QAAKI;KAAS;IAEvB,kEAAkE;IAClElC,UAAU;QACR,IAAI,CAACU,KAAK;YACR;QACF;QAEA,MAAM+B,WAAW,CAACC;YAChB,MAAM,EAAEhB,YAAY,EAAEZ,YAAY,EAAE,GAAGkB,OAAOC,OAAO;YACrD,IAAIS,MAAMhC,GAAG,KAAKA,KAAK;gBACrBqB,eACEvB,mBAAmB;oBACjBE;oBACAC,UAAUe;oBACVZ;gBACF;YAEJ;QACF;QAEA6B,OAAOC,gBAAgB,CAAC,WAAWH;QACnC,OAAO;YACLE,OAAOE,mBAAmB,CAAC,WAAWJ;QACxC;IACF,GAAG;QAAC/B;KAAI;IAER,OAAO;QACLH;QACA2B;QACAK;QACAC;IACF;AACF"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useOrientation.ts"],"sourcesContent":["\"use client\";\nimport { useEffect, useState } from \"react\";\n\n/**\n * An extremely simple \"polyfill\" for the `window.screen.orientation` just for\n * the `type` value that is required for the `useOrientation` hook.\n *\n * @see {@link https://caniuse.com/screen-orientation}\n * @returns the orientation type either from the `window.screen.orientation` or\n * by comparing the `availHeight` and `availWidth` on the `window.screen`\n * @internal\n */\nexport const getOrientationType = (): OrientationType => {\n if (typeof window === \"undefined\") {\n return \"landscape-primary\";\n }\n\n // Note: at the time of writing this, it looks like only Safari does not\n // support it from my list of browsers\n const screenOrientation = window.screen.orientation?.type;\n if (typeof screenOrientation === \"string\") {\n return screenOrientation;\n }\n\n const { availHeight, availWidth } = window.screen;\n\n return availHeight > availWidth ? \"portrait-primary\" : \"landscape-primary\";\n};\n\n/**\n * This hook uses the {@link https://developer.mozilla.org/en-US/docs/Web/API/ScreenOrientation} API\n * to determine if the screen is landscape or portrait. For browsers that do not\n * support this API yet, it will polyfill that behavior using a resize handler\n * instead.\n *\n * @internal\n * @see {@link https://caniuse.com/screen-orientation}\n * @returns the current orientation type\n */\nexport function useOrientation(): OrientationType {\n const [orientation, setOrientation] = useState(getOrientationType);\n useEffect(() => {\n const handler = (): void => setOrientation(getOrientationType());\n\n const { orientation } = window.screen;\n if (orientation) {\n orientation.addEventListener(\"change\", handler);\n } else {\n window.addEventListener(\"resize\", handler);\n }\n\n return () => {\n if (orientation) {\n orientation.removeEventListener(\"change\", handler);\n } else {\n window.removeEventListener(\"resize\", handler);\n }\n };\n }, []);\n\n return orientation;\n}\n"],"names":["useEffect","useState","getOrientationType","window","screenOrientation","screen","orientation","type","availHeight","availWidth","useOrientation","setOrientation","handler","addEventListener","removeEventListener"],"mappings":"AAAA;AACA,SAASA,SAAS,EAAEC,QAAQ,QAAQ,QAAQ;AAE5C;;;;;;;;CAQC,GACD,OAAO,MAAMC,qBAAqB;IAChC,IAAI,OAAOC,WAAW,aAAa;QACjC,OAAO;IACT;IAEA,wEAAwE;IACxE,sCAAsC;IACtC,MAAMC,oBAAoBD,OAAOE,MAAM,CAACC,WAAW,EAAEC;IACrD,IAAI,OAAOH,sBAAsB,UAAU;QACzC,OAAOA;IACT;IAEA,MAAM,EAAEI,WAAW,EAAEC,UAAU,EAAE,GAAGN,OAAOE,MAAM;IAEjD,OAAOG,cAAcC,aAAa,qBAAqB;AACzD,EAAE;AAEF;;;;;;;;;CASC,GACD,OAAO,SAASC;IACd,MAAM,CAACJ,aAAaK,eAAe,GAAGV,SAASC;IAC/CF,UAAU;QACR,MAAMY,UAAU,IAAYD,eAAeT;QAE3C,MAAM,EAAEI,WAAW,EAAE,GAAGH,OAAOE,MAAM;QACrC,IAAIC,aAAa;YACfA,YAAYO,gBAAgB,CAAC,UAAUD;QACzC,OAAO;YACLT,OAAOU,gBAAgB,CAAC,UAAUD;QACpC;QAEA,OAAO;YACL,IAAIN,aAAa;gBACfA,YAAYQ,mBAAmB,CAAC,UAAUF;YAC5C,OAAO;gBACLT,OAAOW,mBAAmB,CAAC,UAAUF;YACvC;QACF;IACF,GAAG,EAAE;IAEL,OAAON;AACT"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/usePageInactive.ts"],"sourcesContent":["\"use client\";\nimport { useEffect } from \"react\";\n\nconst noop = (): void => {\n // do nothing\n};\n\n/**\n * When this is set to `\"focus\"`, the change handler will be fired whenever the\n * window gains or loses focus.\n *\n * When this is set to `visibility`, the change handler will be fired when the\n * browser is no longer partially visible or becomes partially visible.\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Document/visibilityState\n * @remarks \\@since 6.0.0\n */\nexport type PageInactiveType = \"focus\" | \"visibility\";\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface PageInactiveOptions {\n /**\n * @see {@link PageInactiveType}\n * @defaultValue `\"focus\"`\n */\n type?: PageInactiveType;\n\n /**\n * @defaultValue `false`\n */\n disabled?: boolean;\n\n /**\n * This will be called whenever the page activity changes based on the\n * {@link PageInactiveType}.\n */\n onChange(active: boolean): void;\n\n /**\n * This will be fired whenever the {@link disabled} state is `true` which can\n * be useful for clearing pending timers or resetting state.\n *\n * Since this is passed to a `useEffect` as a dependency, you might have to\n * wrap this in a `useCallback` if unexpected re-rendering or errors occurs.\n *\n * @defaultValue `() => {}`\n */\n onDisabledCleanup?(): void;\n}\n\n/**\n * @example\n * ```ts\n * import { usePageInactive } from \"@react-md/core\";\n * import { useCallback, useEffect, useRef, useState } from \"react\";\n *\n * function Example(): null {\n * const [visible, setVisible] = useState(false);\n * const timeout = useRef<number | undefined>();\n * const startTimeout = useCallback(() => {\n * timeout.current = window.setTimeout(() => {\n * setVisible(false);\n * }, 10000);\n * }, []);\n *\n * usePageInactive({\n * onChange(active) {\n * if (!active) {\n * window.clearTimeout(timeout.current);\n * setVisible(false);\n * } else {\n * startTimeout();\n * }\n * }\n * });\n *\n * // pretend implementation\n * return null;\n * }\n * ```\n * @remarks \\@since 6.0.0\n */\nexport function usePageInactive(options: PageInactiveOptions): void {\n const {\n type = \"focus\",\n disabled,\n onChange,\n onDisabledCleanup = noop,\n } = options;\n useEffect(() => {\n if (disabled) {\n onDisabledCleanup();\n return;\n }\n\n const callback = (event: Event): void => {\n let active = document.visibilityState === \"visible\";\n if (event.type === \"blur\") {\n active = false;\n } else if (event.type === \"focus\") {\n active = true;\n }\n\n onChange(active);\n };\n\n document.addEventListener(\"visibilitychange\", callback);\n if (type === \"focus\") {\n window.addEventListener(\"blur\", callback);\n window.addEventListener(\"focus\", callback);\n }\n\n return () => {\n document.removeEventListener(\"visibilitychange\", callback);\n window.removeEventListener(\"blur\", callback);\n window.removeEventListener(\"focus\", callback);\n };\n }, [disabled, onChange, onDisabledCleanup, type]);\n}\n"],"names":["useEffect","noop","usePageInactive","options","type","disabled","onChange","onDisabledCleanup","callback","event","active","document","visibilityState","addEventListener","window","removeEventListener"],"mappings":"AAAA;AACA,SAASA,SAAS,QAAQ,QAAQ;AAElC,MAAMC,OAAO;AACX,aAAa;AACf;AA+CA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+BC,GACD,OAAO,SAASC,gBAAgBC,OAA4B;IAC1D,MAAM,EACJC,OAAO,OAAO,EACdC,QAAQ,EACRC,QAAQ,EACRC,oBAAoBN,IAAI,EACzB,GAAGE;IACJH,UAAU;QACR,IAAIK,UAAU;YACZE;YACA;QACF;QAEA,MAAMC,WAAW,CAACC;YAChB,IAAIC,SAASC,SAASC,eAAe,KAAK;YAC1C,IAAIH,MAAML,IAAI,KAAK,QAAQ;gBACzBM,SAAS;YACX,OAAO,IAAID,MAAML,IAAI,KAAK,SAAS;gBACjCM,SAAS;YACX;YAEAJ,SAASI;QACX;QAEAC,SAASE,gBAAgB,CAAC,oBAAoBL;QAC9C,IAAIJ,SAAS,SAAS;YACpBU,OAAOD,gBAAgB,CAAC,QAAQL;YAChCM,OAAOD,gBAAgB,CAAC,SAASL;QACnC;QAEA,OAAO;YACLG,SAASI,mBAAmB,CAAC,oBAAoBP;YACjDM,OAAOC,mBAAmB,CAAC,QAAQP;YACnCM,OAAOC,mBAAmB,CAAC,SAASP;QACtC;IACF,GAAG;QAACH;QAAUC;QAAUC;QAAmBH;KAAK;AAClD"}
@@ -0,0 +1,71 @@
1
+ "use client";
2
+ import { useEffect } from "react";
3
+ import { delegateEvent } from "./delegateEvent.js";
4
+ /**
5
+ * This hook can be used to listen to the entire window resizing. If you need to
6
+ * observe specific elements resizing, check out the {@link useResizeObserver}
7
+ * hook instead.
8
+ *
9
+ * @example
10
+ * Simple Example
11
+ * ```tsx
12
+ * import { useResizeListener } from "@react-md/core";
13
+ * import type { ReactElement } from "react";
14
+ * import { useState } from "react";
15
+ *
16
+ * function Example(): ReactElement {
17
+ * const [size, setSize] = useState({
18
+ * height: window.innerHeight,
19
+ * width: window.innerWidth,
20
+ * }):
21
+ *
22
+ * useResizeListener({
23
+ * onUpdate(event) {
24
+ * setSize({
25
+ * height: window.innerHeight,
26
+ * width: window.innerWidth,
27
+ * });
28
+ * },
29
+ * });
30
+ *
31
+ * return (
32
+ * <>
33
+ * The current window size:
34
+ * <pre><code>{JSON.stringify(size, null, 2)}</code></pre>
35
+ * </>
36
+ * );
37
+ * }
38
+ * ```
39
+ *
40
+ * @remarks \@since 6.0.0 Updated the API to match the `useResizeObserver` and
41
+ * `useIntersectionObserver` hooks by having an `onUpdate` callback and include
42
+ * the `AddEventListenerOptions` as part of the hook options.
43
+ */ export function useResizeListener(options) {
44
+ const { once, signal, capture, passive, throttle = true, disabled = false, onUpdate } = options;
45
+ useEffect(()=>{
46
+ if (disabled) {
47
+ return;
48
+ }
49
+ const eventHandler = delegateEvent("resize", window, throttle, {
50
+ once,
51
+ signal,
52
+ capture,
53
+ passive
54
+ });
55
+ eventHandler.add(onUpdate);
56
+ window.dispatchEvent(new Event("resize"));
57
+ return ()=>{
58
+ eventHandler.remove(onUpdate);
59
+ };
60
+ }, [
61
+ capture,
62
+ disabled,
63
+ onUpdate,
64
+ once,
65
+ passive,
66
+ signal,
67
+ throttle
68
+ ]);
69
+ }
70
+
71
+ //# sourceMappingURL=useResizeListener.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useResizeListener.ts"],"sourcesContent":["\"use client\";\nimport { useEffect } from \"react\";\nimport { delegateEvent } from \"./delegateEvent.js\";\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nimport { useResizeObserver } from \"./useResizeObserver.js\";\n\n/**\n * @remarks \\@since 6.0.0 Updated the API\n */\nexport interface ResizeListenerOptions extends AddEventListenerOptions {\n /**\n * Set this to `false` to disable throttling with\n * `window.requestAnimationFrame`.\n *\n * @defaultValue `true`\n */\n throttle?: boolean;\n\n /**\n * Set this to `true` to disable attaching the resize event handler.\n *\n * @defaultValue `false`\n */\n disabled?: boolean;\n\n /**\n * This function will be called whenever the resize event is fired on the\n * `window`. This should be wrapped in `useCallback`.\n */\n onUpdate(event: Event): void;\n}\n\n/**\n * This hook can be used to listen to the entire window resizing. If you need to\n * observe specific elements resizing, check out the {@link useResizeObserver}\n * hook instead.\n *\n * @example\n * Simple Example\n * ```tsx\n * import { useResizeListener } from \"@react-md/core\";\n * import type { ReactElement } from \"react\";\n * import { useState } from \"react\";\n *\n * function Example(): ReactElement {\n * const [size, setSize] = useState({\n * height: window.innerHeight,\n * width: window.innerWidth,\n * }):\n *\n * useResizeListener({\n * onUpdate(event) {\n * setSize({\n * height: window.innerHeight,\n * width: window.innerWidth,\n * });\n * },\n * });\n *\n * return (\n * <>\n * The current window size:\n * <pre><code>{JSON.stringify(size, null, 2)}</code></pre>\n * </>\n * );\n * }\n * ```\n *\n * @remarks \\@since 6.0.0 Updated the API to match the `useResizeObserver` and\n * `useIntersectionObserver` hooks by having an `onUpdate` callback and include\n * the `AddEventListenerOptions` as part of the hook options.\n */\nexport function useResizeListener(options: ResizeListenerOptions): void {\n const {\n once,\n signal,\n capture,\n passive,\n throttle = true,\n disabled = false,\n onUpdate,\n } = options;\n\n useEffect(() => {\n if (disabled) {\n return;\n }\n\n const eventHandler = delegateEvent(\"resize\", window, throttle, {\n once,\n signal,\n capture,\n passive,\n });\n eventHandler.add(onUpdate);\n\n window.dispatchEvent(new Event(\"resize\"));\n return () => {\n eventHandler.remove(onUpdate);\n };\n }, [capture, disabled, onUpdate, once, passive, signal, throttle]);\n}\n"],"names":["useEffect","delegateEvent","useResizeListener","options","once","signal","capture","passive","throttle","disabled","onUpdate","eventHandler","window","add","dispatchEvent","Event","remove"],"mappings":"AAAA;AACA,SAASA,SAAS,QAAQ,QAAQ;AAClC,SAASC,aAAa,QAAQ,qBAAqB;AA8BnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAuCC,GACD,OAAO,SAASC,kBAAkBC,OAA8B;IAC9D,MAAM,EACJC,IAAI,EACJC,MAAM,EACNC,OAAO,EACPC,OAAO,EACPC,WAAW,IAAI,EACfC,WAAW,KAAK,EAChBC,QAAQ,EACT,GAAGP;IAEJH,UAAU;QACR,IAAIS,UAAU;YACZ;QACF;QAEA,MAAME,eAAeV,cAAc,UAAUW,QAAQJ,UAAU;YAC7DJ;YACAC;YACAC;YACAC;QACF;QACAI,aAAaE,GAAG,CAACH;QAEjBE,OAAOE,aAAa,CAAC,IAAIC,MAAM;QAC/B,OAAO;YACLJ,aAAaK,MAAM,CAACN;QACtB;IACF,GAAG;QAACJ;QAASG;QAAUC;QAAUN;QAAMG;QAASF;QAAQG;KAAS;AACnE"}
@@ -0,0 +1,134 @@
1
+ "use client";
2
+ function _define_property(obj, key, value) {
3
+ if (key in obj) {
4
+ Object.defineProperty(obj, key, {
5
+ value: value,
6
+ enumerable: true,
7
+ configurable: true,
8
+ writable: true
9
+ });
10
+ } else {
11
+ obj[key] = value;
12
+ }
13
+ return obj;
14
+ }
15
+ import { useEffect } from "react";
16
+ import { useEnsuredRef } from "./useEnsuredRef.js";
17
+ /**
18
+ * @internal
19
+ * @remarks \@since 6.0.0 This was added to help with testing. The
20
+ * `subscriptions` and `sharedObserver` used to be module-level variables but
21
+ * moving to a class makes it easier to mock. Checkout the
22
+ * `src/tests-utils/ResizeObserver.ts`
23
+ */ export class ResizeObserverManager {
24
+ constructor(){
25
+ _define_property(this, "frame", void 0);
26
+ _define_property(this, "subscriptions", void 0);
27
+ /**
28
+ * Why is there a single shared observer instead of multiple and a
29
+ * "subscription" model?
30
+ *
31
+ * Note: Probably a bit of a premature optimization right now...
32
+ *
33
+ * @see https://github.com/WICG/resize-observer/issues/59
34
+ * @internal
35
+ */ _define_property(this, "sharedObserver", void 0);
36
+ _define_property(this, "subscribe", (options)=>{
37
+ const { element, onUpdate, disableHeight, disableWidth } = options;
38
+ // lazy initialize the observer
39
+ const observer = this.sharedObserver || new ResizeObserver((entries)=>{
40
+ // this prevents the `ResizeObserver loop limit exceeded`
41
+ window.cancelAnimationFrame(this.frame);
42
+ this.frame = window.requestAnimationFrame(()=>{
43
+ this.handleResizeEntries(entries);
44
+ });
45
+ });
46
+ this.sharedObserver = observer;
47
+ const updates = this.subscriptions.get(element) || new Set();
48
+ const subscription = {
49
+ onUpdate,
50
+ disableHeight,
51
+ disableWidth
52
+ };
53
+ updates.add(subscription);
54
+ if (!this.subscriptions.has(element)) {
55
+ this.subscriptions.set(element, updates);
56
+ }
57
+ observer.observe(element);
58
+ return ()=>{
59
+ observer.unobserve(element);
60
+ updates.delete(subscription);
61
+ };
62
+ });
63
+ _define_property(this, "handleResizeEntries", (entries)=>{
64
+ for (const entry of entries){
65
+ const targetSubscriptions = this.subscriptions.get(entry.target);
66
+ // shouldn't really happen
67
+ /* c8 ignore start */ if (!targetSubscriptions) {
68
+ continue;
69
+ }
70
+ /* c8 ignore end */ const entries = targetSubscriptions.values();
71
+ for (const subscription of entries){
72
+ const { height, width } = entry.contentRect;
73
+ const { scrollHeight, scrollWidth } = entry.target;
74
+ const { onUpdate, size, disableHeight, disableWidth } = subscription;
75
+ const isHeightChange = !disableHeight && (!size || size.height !== height || size.scrollHeight !== scrollHeight);
76
+ const isWidthChange = !disableWidth && (!size || size.width !== width || size.scrollWidth !== scrollWidth);
77
+ subscription.size = {
78
+ height,
79
+ width,
80
+ scrollHeight,
81
+ scrollWidth
82
+ };
83
+ if (isHeightChange || isWidthChange) {
84
+ onUpdate(entry);
85
+ }
86
+ }
87
+ }
88
+ });
89
+ this.frame = 0;
90
+ this.subscriptions = new Map();
91
+ }
92
+ }
93
+ /**
94
+ * @internal
95
+ * @remarks \@since 6.0.0
96
+ */ export const resizeObserverManager = new ResizeObserverManager();
97
+ /**
98
+ * The resize observer is used to track the size changes of a specific element.
99
+ * For most cases you can use the {@link useElementSize} instead, but this hook
100
+ * can be used for more complex behavior with the {@link ResizeObserverEntry}.
101
+ *
102
+ * @remarks
103
+ * \@since 2.3.0
104
+ * \@since 6.0.0 The API was updated to match the `useIntersectionObserver`
105
+ * implementation -- accepts only a single object parameter and returns a
106
+ * {@link RefCallback} instead of `[nodeRef, refCallback]`
107
+ */ export function useResizeObserver(options) {
108
+ const { ref, onUpdate, disabled, disableHeight = false, disableWidth = false } = options;
109
+ const [targetNodeRef, refCallback] = useEnsuredRef(ref);
110
+ useEffect(()=>{
111
+ const element = targetNodeRef.current;
112
+ if (disabled || disableHeight && disableWidth || !element) {
113
+ return;
114
+ }
115
+ const unsubscribe = resizeObserverManager.subscribe({
116
+ element,
117
+ onUpdate,
118
+ disableHeight,
119
+ disableWidth
120
+ });
121
+ return ()=>{
122
+ unsubscribe();
123
+ };
124
+ }, [
125
+ disableHeight,
126
+ disableWidth,
127
+ disabled,
128
+ onUpdate,
129
+ targetNodeRef
130
+ ]);
131
+ return refCallback;
132
+ }
133
+
134
+ //# sourceMappingURL=useResizeObserver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useResizeObserver.ts"],"sourcesContent":["\"use client\";\nimport { useEffect, type Ref, type RefCallback } from \"react\";\nimport { useEnsuredRef } from \"./useEnsuredRef.js\";\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nimport { type useElementSize } from \"./useElementSize.js\";\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport type ResizeObserverEntryCallback = (entry: ResizeObserverEntry) => void;\n\n/** @internal */\ntype Unsubscribe = () => void;\n\n/** @internal */\ninterface TargetSize {\n height: number;\n width: number;\n scrollHeight: number;\n scrollWidth: number;\n}\n\n/** @internal */\ninterface TargetSubscription {\n readonly onUpdate: ResizeObserverEntryCallback;\n readonly disableHeight: boolean;\n readonly disableWidth: boolean;\n\n size?: TargetSize;\n}\n\n/** @internal */\ninterface SubscribeOptions {\n element: Element;\n onUpdate: ResizeObserverEntryCallback;\n disableHeight: boolean;\n disableWidth: boolean;\n}\n\n/**\n * @internal\n * @remarks \\@since 6.0.0 This was added to help with testing. The\n * `subscriptions` and `sharedObserver` used to be module-level variables but\n * moving to a class makes it easier to mock. Checkout the\n * `src/tests-utils/ResizeObserver.ts`\n */\nexport class ResizeObserverManager {\n frame: number;\n subscriptions: Map<Element, Set<TargetSubscription>>;\n\n /**\n * Why is there a single shared observer instead of multiple and a\n * \"subscription\" model?\n *\n * Note: Probably a bit of a premature optimization right now...\n *\n * @see https://github.com/WICG/resize-observer/issues/59\n * @internal\n */\n sharedObserver: ResizeObserver | undefined;\n\n constructor() {\n this.frame = 0;\n this.subscriptions = new Map();\n }\n\n subscribe = (options: SubscribeOptions): Unsubscribe => {\n const { element, onUpdate, disableHeight, disableWidth } = options;\n\n // lazy initialize the observer\n const observer =\n this.sharedObserver ||\n new ResizeObserver((entries) => {\n // this prevents the `ResizeObserver loop limit exceeded`\n window.cancelAnimationFrame(this.frame);\n this.frame = window.requestAnimationFrame(() => {\n this.handleResizeEntries(entries);\n });\n });\n this.sharedObserver = observer;\n\n const updates = this.subscriptions.get(element) || new Set();\n const subscription: TargetSubscription = {\n onUpdate,\n disableHeight,\n disableWidth,\n };\n updates.add(subscription);\n if (!this.subscriptions.has(element)) {\n this.subscriptions.set(element, updates);\n }\n\n observer.observe(element);\n\n return () => {\n observer.unobserve(element);\n updates.delete(subscription);\n };\n };\n\n handleResizeEntries = (entries: ResizeObserverEntry[]): void => {\n for (const entry of entries) {\n const targetSubscriptions = this.subscriptions.get(entry.target);\n // shouldn't really happen\n /* c8 ignore start */\n if (!targetSubscriptions) {\n continue;\n }\n /* c8 ignore end */\n\n const entries = targetSubscriptions.values();\n for (const subscription of entries) {\n const { height, width } = entry.contentRect;\n const { scrollHeight, scrollWidth } = entry.target;\n const { onUpdate, size, disableHeight, disableWidth } = subscription;\n const isHeightChange =\n !disableHeight &&\n (!size ||\n size.height !== height ||\n size.scrollHeight !== scrollHeight);\n const isWidthChange =\n !disableWidth &&\n (!size || size.width !== width || size.scrollWidth !== scrollWidth);\n\n subscription.size = {\n height,\n width,\n scrollHeight,\n scrollWidth,\n };\n if (isHeightChange || isWidthChange) {\n onUpdate(entry);\n }\n }\n }\n };\n}\n\n/**\n * @internal\n * @remarks \\@since 6.0.0\n */\nexport const resizeObserverManager = new ResizeObserverManager();\n\n/**\n * @remarks\n * \\@since 2.3.0\n * \\@since 6.0.0 Renamed from `UseResizeObserverOptions` and added\n * `onUpdate`/`disabled` options.\n */\nexport interface ResizeObserverHookOptions<E extends HTMLElement> {\n /**\n * An optional ref to merge with the ref returned by this hook.\n */\n ref?: Ref<E>;\n\n /**\n * **Must be wrapped in `useCallback` to prevent re-creating the\n * ResizeObserver each render.**\n *\n * This function will be called whenever the target element resizes.\n *\n * @see {@link useResizeObserver} for an example.\n */\n onUpdate: ResizeObserverEntryCallback;\n\n /**\n * Set this to `true` to prevent observing the element's size changes. THis is\n * equivalent to not attaching the returned ref to any element.\n *\n * @defaultValue `false`\n */\n disabled?: boolean;\n\n /**\n * Set this to `true` if the {@link onUpdate} should not be fired for height\n * changes.\n *\n * @defaultValue `false`\n */\n disableHeight?: boolean;\n\n /**\n * Set this to `true` if the {@link onUpdate} should not be fired for width\n * changes.\n *\n * @defaultValue `false`\n */\n disableWidth?: boolean;\n}\n\n/**\n * The resize observer is used to track the size changes of a specific element.\n * For most cases you can use the {@link useElementSize} instead, but this hook\n * can be used for more complex behavior with the {@link ResizeObserverEntry}.\n *\n * @remarks\n * \\@since 2.3.0\n * \\@since 6.0.0 The API was updated to match the `useIntersectionObserver`\n * implementation -- accepts only a single object parameter and returns a\n * {@link RefCallback} instead of `[nodeRef, refCallback]`\n */\nexport function useResizeObserver<E extends HTMLElement>(\n options: ResizeObserverHookOptions<E>\n): RefCallback<E> {\n const {\n ref,\n onUpdate,\n disabled,\n disableHeight = false,\n disableWidth = false,\n } = options;\n\n const [targetNodeRef, refCallback] = useEnsuredRef(ref);\n useEffect(() => {\n const element = targetNodeRef.current;\n if (disabled || (disableHeight && disableWidth) || !element) {\n return;\n }\n\n const unsubscribe = resizeObserverManager.subscribe({\n element,\n onUpdate,\n disableHeight,\n disableWidth,\n });\n\n return () => {\n unsubscribe();\n };\n }, [disableHeight, disableWidth, disabled, onUpdate, targetNodeRef]);\n\n return refCallback;\n}\n"],"names":["useEffect","useEnsuredRef","ResizeObserverManager","constructor","frame","subscriptions","sharedObserver","subscribe","options","element","onUpdate","disableHeight","disableWidth","observer","ResizeObserver","entries","window","cancelAnimationFrame","requestAnimationFrame","handleResizeEntries","updates","get","Set","subscription","add","has","set","observe","unobserve","delete","entry","targetSubscriptions","target","values","height","width","contentRect","scrollHeight","scrollWidth","size","isHeightChange","isWidthChange","Map","resizeObserverManager","useResizeObserver","ref","disabled","targetNodeRef","refCallback","current","unsubscribe"],"mappings":"AAAA;;;;;;;;;;;;;;AACA,SAASA,SAAS,QAAoC,QAAQ;AAC9D,SAASC,aAAa,QAAQ,qBAAqB;AAsCnD;;;;;;CAMC,GACD,OAAO,MAAMC;IAeXC,aAAc;QAddC,uBAAAA,SAAAA,KAAAA;QACAC,uBAAAA,iBAAAA,KAAAA;QAEA;;;;;;;;GAQC,GACDC,uBAAAA,kBAAAA,KAAAA;QAOAC,uBAAAA,aAAY,CAACC;YACX,MAAM,EAAEC,OAAO,EAAEC,QAAQ,EAAEC,aAAa,EAAEC,YAAY,EAAE,GAAGJ;YAE3D,+BAA+B;YAC/B,MAAMK,WACJ,IAAI,CAACP,cAAc,IACnB,IAAIQ,eAAe,CAACC;gBAClB,yDAAyD;gBACzDC,OAAOC,oBAAoB,CAAC,IAAI,CAACb,KAAK;gBACtC,IAAI,CAACA,KAAK,GAAGY,OAAOE,qBAAqB,CAAC;oBACxC,IAAI,CAACC,mBAAmB,CAACJ;gBAC3B;YACF;YACF,IAAI,CAACT,cAAc,GAAGO;YAEtB,MAAMO,UAAU,IAAI,CAACf,aAAa,CAACgB,GAAG,CAACZ,YAAY,IAAIa;YACvD,MAAMC,eAAmC;gBACvCb;gBACAC;gBACAC;YACF;YACAQ,QAAQI,GAAG,CAACD;YACZ,IAAI,CAAC,IAAI,CAAClB,aAAa,CAACoB,GAAG,CAAChB,UAAU;gBACpC,IAAI,CAACJ,aAAa,CAACqB,GAAG,CAACjB,SAASW;YAClC;YAEAP,SAASc,OAAO,CAAClB;YAEjB,OAAO;gBACLI,SAASe,SAAS,CAACnB;gBACnBW,QAAQS,MAAM,CAACN;YACjB;QACF;QAEAJ,uBAAAA,uBAAsB,CAACJ;YACrB,KAAK,MAAMe,SAASf,QAAS;gBAC3B,MAAMgB,sBAAsB,IAAI,CAAC1B,aAAa,CAACgB,GAAG,CAACS,MAAME,MAAM;gBAC/D,0BAA0B;gBAC1B,mBAAmB,GACnB,IAAI,CAACD,qBAAqB;oBACxB;gBACF;gBACA,iBAAiB,GAEjB,MAAMhB,UAAUgB,oBAAoBE,MAAM;gBAC1C,KAAK,MAAMV,gBAAgBR,QAAS;oBAClC,MAAM,EAAEmB,MAAM,EAAEC,KAAK,EAAE,GAAGL,MAAMM,WAAW;oBAC3C,MAAM,EAAEC,YAAY,EAAEC,WAAW,EAAE,GAAGR,MAAME,MAAM;oBAClD,MAAM,EAAEtB,QAAQ,EAAE6B,IAAI,EAAE5B,aAAa,EAAEC,YAAY,EAAE,GAAGW;oBACxD,MAAMiB,iBACJ,CAAC7B,iBACA,CAAA,CAAC4B,QACAA,KAAKL,MAAM,KAAKA,UAChBK,KAAKF,YAAY,KAAKA,YAAW;oBACrC,MAAMI,gBACJ,CAAC7B,gBACA,CAAA,CAAC2B,QAAQA,KAAKJ,KAAK,KAAKA,SAASI,KAAKD,WAAW,KAAKA,WAAU;oBAEnEf,aAAagB,IAAI,GAAG;wBAClBL;wBACAC;wBACAE;wBACAC;oBACF;oBACA,IAAIE,kBAAkBC,eAAe;wBACnC/B,SAASoB;oBACX;gBACF;YACF;QACF;QAzEE,IAAI,CAAC1B,KAAK,GAAG;QACb,IAAI,CAACC,aAAa,GAAG,IAAIqC;IAC3B;AAwEF;AAEA;;;CAGC,GACD,OAAO,MAAMC,wBAAwB,IAAIzC,wBAAwB;AAiDjE;;;;;;;;;;CAUC,GACD,OAAO,SAAS0C,kBACdpC,OAAqC;IAErC,MAAM,EACJqC,GAAG,EACHnC,QAAQ,EACRoC,QAAQ,EACRnC,gBAAgB,KAAK,EACrBC,eAAe,KAAK,EACrB,GAAGJ;IAEJ,MAAM,CAACuC,eAAeC,YAAY,GAAG/C,cAAc4C;IACnD7C,UAAU;QACR,MAAMS,UAAUsC,cAAcE,OAAO;QACrC,IAAIH,YAAanC,iBAAiBC,gBAAiB,CAACH,SAAS;YAC3D;QACF;QAEA,MAAMyC,cAAcP,sBAAsBpC,SAAS,CAAC;YAClDE;YACAC;YACAC;YACAC;QACF;QAEA,OAAO;YACLsC;QACF;IACF,GAAG;QAACvC;QAAeC;QAAckC;QAAUpC;QAAUqC;KAAc;IAEnE,OAAOC;AACT"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useThrottledFunction.ts"],"sourcesContent":["\"use client\";\nimport { useCallback, useEffect, useRef } from \"react\";\nimport type { AnyFunction } from \"./types.js\";\nimport { useIsomorphicLayoutEffect } from \"./useIsomorphicLayoutEffect.js\";\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport type ThrottledFunction<F extends AnyFunction> = (\n ...args: Parameters<F>\n) => ReturnType<F>;\n\n/**\n * Creates a function that will only be called once every X milliseconds.\n *\n * @example\n * Throttling Search API Requests\n * ```tsx\n * import { TextField, useThrottledFunction, useUnmounted } from \"@react-md/core\";\n * import { useState } from \"react\";\n * import type { ReactElement } from \"react\";\n *\n * interface State {\n * error?: unknown\n * loading: boolean;\n * results?: {\n * // pretend some search results\n * id: string;\n * name: string;\n * }[];\n * }\n *\n * function Example(): ReactElement {\n * const [state, setState] = useState<State>({\n * loading: false,\n * });\n * // this is only required for async actions\n * const unmounted = useUnmounted();\n *\n * // A new search request will be fired once every 500ms as the user types.\n * // can't use the event here since React uses synthetic events\n * const search = useThrottledFunction(async (q: string) => {\n * setState({\n * loading: true,\n * error: undefined,\n * results: undefined,\n * });\n *\n * try {\n * const response = await fetch('/search', {\n * method: 'POST',\n * headers: {\n * 'Content-Type': 'application/json',\n * },\n * body: JSON.stringify({ q }),\n * });\n * const json = await response.json();\n *\n * if (!unmounted.current) {\n * setState({\n * loading: false,\n * results: json,\n * });\n * }\n * } catch (error) {\n * if (!unmounted.current) {\n * setState({\n * error,\n * loading: false,\n * });\n * }\n * }\n * }, 500);\n *\n * return (\n * <TextField\n * type=\"search\"\n * label=\"Search\"\n * onChange={(event) => search(event.currentTarget.value)}\n * />\n * );\n * }\n * ```\n *\n * @see `useDebouncedFunction` for debounce behavior instead. (Call a\n * function only if it has not been called again for X milliseconds).\n * @remarks \\@since 6.0.0\n */\nexport function useThrottledFunction<F extends AnyFunction>(\n func: F,\n wait: number\n): ThrottledFunction<F> {\n const args = useRef<Parameters<F>>();\n const result = useRef<ReturnType<F>>();\n const timeout = useRef<number | undefined>();\n const funcRef = useRef(func);\n const lastCalledTime = useRef(0);\n\n useIsomorphicLayoutEffect(() => {\n funcRef.current = func;\n });\n\n useEffect(() => {\n return () => {\n window.clearTimeout(timeout.current);\n };\n }, []);\n\n return useCallback(\n (...nextArgs) => {\n args.current = nextArgs;\n\n const now = Date.now();\n const remaining = wait - (now - lastCalledTime.current);\n if (remaining <= 0 || remaining > wait) {\n lastCalledTime.current = now;\n result.current = funcRef.current(...args.current);\n } else if (!timeout.current) {\n timeout.current = window.setTimeout(() => {\n lastCalledTime.current = Date.now();\n timeout.current = undefined;\n // should exist by this time\n result.current = funcRef.current(...(args.current as Parameters<F>));\n }, remaining);\n }\n\n return result.current as ReturnType<F>;\n },\n [wait]\n );\n}\n"],"names":["useCallback","useEffect","useRef","useIsomorphicLayoutEffect","useThrottledFunction","func","wait","args","result","timeout","funcRef","lastCalledTime","current","window","clearTimeout","nextArgs","now","Date","remaining","setTimeout","undefined"],"mappings":"AAAA;AACA,SAASA,WAAW,EAAEC,SAAS,EAAEC,MAAM,QAAQ,QAAQ;AAEvD,SAASC,yBAAyB,QAAQ,iCAAiC;AAS3E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2EC,GACD,OAAO,SAASC,qBACdC,IAAO,EACPC,IAAY;IAEZ,MAAMC,OAAOL;IACb,MAAMM,SAASN;IACf,MAAMO,UAAUP;IAChB,MAAMQ,UAAUR,OAAOG;IACvB,MAAMM,iBAAiBT,OAAO;IAE9BC,0BAA0B;QACxBO,QAAQE,OAAO,GAAGP;IACpB;IAEAJ,UAAU;QACR,OAAO;YACLY,OAAOC,YAAY,CAACL,QAAQG,OAAO;QACrC;IACF,GAAG,EAAE;IAEL,OAAOZ,YACL,CAAC,GAAGe;QACFR,KAAKK,OAAO,GAAGG;QAEf,MAAMC,MAAMC,KAAKD,GAAG;QACpB,MAAME,YAAYZ,OAAQU,CAAAA,MAAML,eAAeC,OAAO,AAAD;QACrD,IAAIM,aAAa,KAAKA,YAAYZ,MAAM;YACtCK,eAAeC,OAAO,GAAGI;YACzBR,OAAOI,OAAO,GAAGF,QAAQE,OAAO,IAAIL,KAAKK,OAAO;QAClD,OAAO,IAAI,CAACH,QAAQG,OAAO,EAAE;YAC3BH,QAAQG,OAAO,GAAGC,OAAOM,UAAU,CAAC;gBAClCR,eAAeC,OAAO,GAAGK,KAAKD,GAAG;gBACjCP,QAAQG,OAAO,GAAGQ;gBAClB,4BAA4B;gBAC5BZ,OAAOI,OAAO,GAAGF,QAAQE,OAAO,IAAKL,KAAKK,OAAO;YACnD,GAAGM;QACL;QAEA,OAAOV,OAAOI,OAAO;IACvB,GACA;QAACN;KAAK;AAEV"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useToggle.ts"],"sourcesContent":["\"use client\";\nimport { useCallback, useState } from \"react\";\nimport type { UseStateInitializer, UseStateSetter } from \"./types.js\";\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface ToggleHookReturnValue {\n toggled: boolean;\n setToggled: UseStateSetter<boolean>;\n toggle(): void;\n enable(): void;\n disable(): void;\n}\n\n/**\n *\n * @example\n * Simple Example\n * ```tsx\n * import { Button, useToggle } from \"@react-md/core\";\n * import type { ReactElement } from \"react\";\n *\n * function Example(): ReactElement {\n * const { toggled, toggle } = useToggle();\n *\n * return (\n * <>\n * <Button onClick=[toggle]>Toggle</Button>\n * {`Toggled: ${toggled}`}\n * </>\n * );\n * }\n * ```\n *\n * @param defaultValue - `false`\n */\nexport function useToggle(\n defaultValue: UseStateInitializer<boolean> = false\n): Readonly<ToggleHookReturnValue> {\n const [toggled, setToggled] = useState(defaultValue);\n\n return {\n toggled,\n setToggled,\n toggle: useCallback(() => {\n setToggled((prevToggled) => !prevToggled);\n }, []),\n enable: useCallback(() => {\n setToggled(true);\n }, []),\n disable: useCallback(() => {\n setToggled(false);\n }, []),\n };\n}\n"],"names":["useCallback","useState","useToggle","defaultValue","toggled","setToggled","toggle","prevToggled","enable","disable"],"mappings":"AAAA;AACA,SAASA,WAAW,EAAEC,QAAQ,QAAQ,QAAQ;AAc9C;;;;;;;;;;;;;;;;;;;;;CAqBC,GACD,OAAO,SAASC,UACdC,eAA6C,KAAK;IAElD,MAAM,CAACC,SAASC,WAAW,GAAGJ,SAASE;IAEvC,OAAO;QACLC;QACAC;QACAC,QAAQN,YAAY;YAClBK,WAAW,CAACE,cAAgB,CAACA;QAC/B,GAAG,EAAE;QACLC,QAAQR,YAAY;YAClBK,WAAW;QACb,GAAG,EAAE;QACLI,SAAST,YAAY;YACnBK,WAAW;QACb,GAAG,EAAE;IACP;AACF"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useUnmounted.ts"],"sourcesContent":["\"use client\";\nimport { useEffect, useRef } from \"react\";\nimport type { NonNullRef } from \"./types.js\";\n\n/**\n * @example\n * Simple Example\n * ```tsx\n * import { useUnmounted } from \"@react-md/core\";\n * import { useEffect, useState } from \"react\";\n *\n * function Example(): ReactElement {\n * const [state, setState] = useState({ loading: false });\n * const unmounted = useUnmounted();\n *\n * useEffect(() => {\n * async function load(): void {\n * const result = await fetch('/some-api');\n * const json = await response.json();\n * if (!unmounted.current) {\n * setState({ loading: false, result: json });\n * }\n * }\n *\n * setState({ loading: true });\n * load();\n * }, [unmounted]);\n *\n * return null;\n * }\n * ```\n * @remarks \\@since 6.0.0\n */\nexport function useUnmounted(): NonNullRef<boolean> {\n const unmounted = useRef(false);\n useEffect(() => {\n unmounted.current = false;\n return () => {\n unmounted.current = true;\n };\n }, []);\n\n return unmounted;\n}\n"],"names":["useEffect","useRef","useUnmounted","unmounted","current"],"mappings":"AAAA;AACA,SAASA,SAAS,EAAEC,MAAM,QAAQ,QAAQ;AAG1C;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4BC,GACD,OAAO,SAASC;IACd,MAAMC,YAAYF,OAAO;IACzBD,UAAU;QACRG,UAAUC,OAAO,GAAG;QACpB,OAAO;YACLD,UAAUC,OAAO,GAAG;QACtB;IACF,GAAG,EAAE;IAEL,OAAOD;AACT"}
@@ -0,0 +1,68 @@
1
+ "use client";
2
+ import { useCallback, useState } from "react";
3
+ import { useSsr } from "./SsrProvider.js";
4
+ import { useResizeListener } from "./useResizeListener.js";
5
+ /**
6
+ * This is just a convenience wrapper around the {@link useResizeListener}.
7
+ *
8
+ * @example
9
+ * Simple Example
10
+ * ```tsx
11
+ * import { useWindowSize } from "@react-md/core";
12
+ * import type { ReactElement } from "react";
13
+ * import { useState } from "react";
14
+ *
15
+ * function Example(): ReactElement {
16
+ * const { height, width } = useWindowSize();
17
+ *
18
+ * return (
19
+ * <>
20
+ * The current window size:
21
+ * <pre><code>{JSON.stringify(size, null, 2)}</code></pre>
22
+ * </>
23
+ * );
24
+ * }
25
+ * ```
26
+ *
27
+ * @remarks \@since 6.0.0
28
+ */ export function useWindowSize(options = {}) {
29
+ const { once, signal, capture, passive, throttle, ssrHeight = 0, ssrWidth = 0, disableWidth, disableHeight } = options;
30
+ const ssr = useSsr();
31
+ const [size, setSize] = useState(()=>{
32
+ if (typeof window === "undefined" || ssr) {
33
+ return {
34
+ height: ssrHeight,
35
+ width: ssrWidth
36
+ };
37
+ }
38
+ return {
39
+ height: window.innerHeight,
40
+ width: window.innerWidth
41
+ };
42
+ });
43
+ useResizeListener({
44
+ once,
45
+ signal,
46
+ capture,
47
+ passive,
48
+ throttle,
49
+ disabled: disableHeight && disableWidth,
50
+ onUpdate: useCallback(()=>{
51
+ setSize((prevSize)=>{
52
+ const nextSize = {
53
+ height: window.innerHeight,
54
+ width: window.innerWidth
55
+ };
56
+ const isHeightChange = !disableHeight && prevSize.height !== nextSize.height;
57
+ const isWidthChange = !disableWidth && prevSize.width !== nextSize.width;
58
+ return isHeightChange || isWidthChange ? nextSize : prevSize;
59
+ });
60
+ }, [
61
+ disableHeight,
62
+ disableWidth
63
+ ])
64
+ });
65
+ return size;
66
+ }
67
+
68
+ //# sourceMappingURL=useWindowSize.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useWindowSize.ts"],"sourcesContent":["\"use client\";\nimport { useCallback, useState } from \"react\";\nimport { useSsr } from \"./SsrProvider.js\";\nimport { type ElementSize } from \"./types.js\";\nimport {\n useResizeListener,\n type ResizeListenerOptions,\n} from \"./useResizeListener.js\";\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface WindowSizeOptions\n extends Omit<ResizeListenerOptions, \"disabled\" | \"onUpdate\"> {\n /**\n * The default value to use in SSR environments for the window's height.\n *\n * @defaultValue `0`\n */\n ssrHeight?: number;\n\n /**\n * The default value to use in SSR environments for the window's width.\n *\n * @defaultValue `0`\n */\n ssrWidth?: number;\n\n /**\n * Set this to `true` to ignore resize events that only updated the height.\n * The hook can be disabled by setting this and {@link disableWidth} to\n * `true`.\n *\n * @defaultValue `false`\n */\n disableHeight?: boolean;\n\n /**\n * Set this to `true` to ignore resize events that only updated the width.\n * The hook can be disabled by setting this and {@link disableHeight} to\n * `true`.\n *\n * @defaultValue `false`\n */\n disableWidth?: boolean;\n}\n\n/**\n * This is just a convenience wrapper around the {@link useResizeListener}.\n *\n * @example\n * Simple Example\n * ```tsx\n * import { useWindowSize } from \"@react-md/core\";\n * import type { ReactElement } from \"react\";\n * import { useState } from \"react\";\n *\n * function Example(): ReactElement {\n * const { height, width } = useWindowSize();\n *\n * return (\n * <>\n * The current window size:\n * <pre><code>{JSON.stringify(size, null, 2)}</code></pre>\n * </>\n * );\n * }\n * ```\n *\n * @remarks \\@since 6.0.0\n */\nexport function useWindowSize(options: WindowSizeOptions = {}): ElementSize {\n const {\n once,\n signal,\n capture,\n passive,\n throttle,\n ssrHeight = 0,\n ssrWidth = 0,\n disableWidth,\n disableHeight,\n } = options;\n\n const ssr = useSsr();\n const [size, setSize] = useState(() => {\n if (typeof window === \"undefined\" || ssr) {\n return {\n height: ssrHeight,\n width: ssrWidth,\n };\n }\n\n return {\n height: window.innerHeight,\n width: window.innerWidth,\n };\n });\n\n useResizeListener({\n once,\n signal,\n capture,\n passive,\n throttle,\n disabled: disableHeight && disableWidth,\n onUpdate: useCallback(() => {\n setSize((prevSize) => {\n const nextSize: ElementSize = {\n height: window.innerHeight,\n width: window.innerWidth,\n };\n\n const isHeightChange =\n !disableHeight && prevSize.height !== nextSize.height;\n const isWidthChange =\n !disableWidth && prevSize.width !== nextSize.width;\n\n return isHeightChange || isWidthChange ? nextSize : prevSize;\n });\n }, [disableHeight, disableWidth]),\n });\n\n return size;\n}\n"],"names":["useCallback","useState","useSsr","useResizeListener","useWindowSize","options","once","signal","capture","passive","throttle","ssrHeight","ssrWidth","disableWidth","disableHeight","ssr","size","setSize","window","height","width","innerHeight","innerWidth","disabled","onUpdate","prevSize","nextSize","isHeightChange","isWidthChange"],"mappings":"AAAA;AACA,SAASA,WAAW,EAAEC,QAAQ,QAAQ,QAAQ;AAC9C,SAASC,MAAM,QAAQ,mBAAmB;AAE1C,SACEC,iBAAiB,QAEZ,yBAAyB;AAwChC;;;;;;;;;;;;;;;;;;;;;;;CAuBC,GACD,OAAO,SAASC,cAAcC,UAA6B,CAAC,CAAC;IAC3D,MAAM,EACJC,IAAI,EACJC,MAAM,EACNC,OAAO,EACPC,OAAO,EACPC,QAAQ,EACRC,YAAY,CAAC,EACbC,WAAW,CAAC,EACZC,YAAY,EACZC,aAAa,EACd,GAAGT;IAEJ,MAAMU,MAAMb;IACZ,MAAM,CAACc,MAAMC,QAAQ,GAAGhB,SAAS;QAC/B,IAAI,OAAOiB,WAAW,eAAeH,KAAK;YACxC,OAAO;gBACLI,QAAQR;gBACRS,OAAOR;YACT;QACF;QAEA,OAAO;YACLO,QAAQD,OAAOG,WAAW;YAC1BD,OAAOF,OAAOI,UAAU;QAC1B;IACF;IAEAnB,kBAAkB;QAChBG;QACAC;QACAC;QACAC;QACAC;QACAa,UAAUT,iBAAiBD;QAC3BW,UAAUxB,YAAY;YACpBiB,QAAQ,CAACQ;gBACP,MAAMC,WAAwB;oBAC5BP,QAAQD,OAAOG,WAAW;oBAC1BD,OAAOF,OAAOI,UAAU;gBAC1B;gBAEA,MAAMK,iBACJ,CAACb,iBAAiBW,SAASN,MAAM,KAAKO,SAASP,MAAM;gBACvD,MAAMS,gBACJ,CAACf,gBAAgBY,SAASL,KAAK,KAAKM,SAASN,KAAK;gBAEpD,OAAOO,kBAAkBC,gBAAgBF,WAAWD;YACtD;QACF,GAAG;YAACX;YAAeD;SAAa;IAClC;IAEA,OAAOG;AACT"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/utils/RenderRecursively.tsx"],"sourcesContent":["// TODO: Figure out how to strictly enforce the data\nimport { type ComponentType, type ReactElement, type ReactNode } from \"react\";\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport type RecursiveItem<T = Record<string, unknown>> = T & {\n items?: readonly RecursiveItem<T>[];\n};\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface RenderRecursiveItemsProps<\n Item = Record<string, unknown>,\n Data = unknown,\n> {\n data?: Data;\n\n /**\n * The current item to render.\n */\n item: RecursiveItem<Item>;\n\n /**\n * The list of parent items which can be used to determine the depth or \"share\n * props\" if the items contained props.\n */\n parents: readonly RecursiveItem<Item>[];\n\n /**\n * This will be provided if the {@link item} had child items and will be the\n * rendered content.\n */\n children?: ReactNode;\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface RenderRecursivelyProps<\n Item = Record<string, unknown>,\n Data = unknown,\n> {\n data?: Data;\n items: readonly RecursiveItem<Item>[];\n\n /**\n * The renderer for each item.\n */\n render: ComponentType<RenderRecursiveItemsProps<Item, Data>>;\n\n /**\n * This should not be used for external users. This is used to build the\n * {@link RenderRecursiveItemsProps.parents} list.\n *\n * @internal\n * @defaultValue `[]`\n */\n parents?: readonly RecursiveItem<Item>[];\n\n /**\n * Gets a React `key` for a specific item. This should be provided if the\n * items can be moved around to improve performance.\n *\n * @example\n * ```ts\n * getItemKey={(item) => item.id}\n * ```\n *\n * @defaultValue `() => ${parents.length}-${index}`.\n */\n getItemKey?(item: RecursiveItem<Item>): string;\n}\n\n/**\n * Helper component for recursively rendering specific data structures (mostly\n * trees). The main use-case is for rendering site navigation and the `Tree`\n * component.\n *\n * @example\n * ```tsx\n * import {\n * buildTree,\n * List,\n * ListItem,\n * ListItemLink,\n * RenderRecursively,\n * TreeData,\n * type DefaultTreeItemNode,\n * type RenderRecursiveItemsProps,\n * } from \"@react-md/core\";\n * import { type ReactElement } from \"react\";\n *\n * const navItems = {\n * \"/\": {\n * href: \"/\",\n * itemId: \"/\",\n * parentId: null,\n * children: \"Home\",\n * },\n * \"/route-1\": {\n * itemId: \"/route-1\",\n * parentId: null,\n * children: \"Collapsible\",\n * },\n * \"/nested-route-1\": {\n * itemId: \"/nested-route-1\",\n * parentId: \"/route-1\",\n * children: \"Child 1\",\n * },\n * \"/nested-route-2\": {\n * itemId: \"/nested-route-2\",\n * parentId: \"/route-2\",\n * children: \"Child 2\",\n * },\n * \"/divider-1\": {\n * itemId: \"/divider-1\",\n * parentId: null\n * },\n * \"/route-2\": {\n * itemId: \"/route-2\"\n * parentId: null,\n * children: \"Route 2\",\n * },\n * } satisfies TreeData;\n *\n * function NestedNavigation(props: RenderRecursiveItemsProps<DefaultTreeItemNode>): ReactElement {\n * const { item, parents, children } = props;\n * const { toggle, toggled: collapsed } = useToggle(false);\n * const { elementProps } = useCollapseTransition({\n * transitionIn: !collapsed,\n * });\n *\n * return (\n * <li>\n * <Button onClick={toggle}>{item.children}</Button>\n * <List {...elementProps}>{children}</List>\n * </li>\n * ):\n * }\n *\n *\n * function Render(props: RenderRecursiveItemsProps<DefaultTreeItemNode>): ReactElement {\n * const { item, parents } = props;\n * if (item.itemId.includes(\"divider\")) {\n * return <Divider />;\n * }\n *\n * if (item.items) {\n * return <NestedNavigation {...props} />\n * }\n *\n * const prefix = parents.map((parent) => parent.itemId).join(\"/\");\n * return (\n * <Link href={`${prefix}${item.itemId}`}>\n * {item.children}\n * </Link>\n * );\n * }\n * ```\n *\n *\n * @remarks \\@since 6.0.0\n */\nexport function RenderRecursively<Item, Data>(\n props: RenderRecursivelyProps<Item, Data>\n): ReactElement {\n const { data, items, render: Render, getItemKey, parents = [] } = props;\n\n return (\n <>\n {items.map((item, index) => {\n let children: ReactNode;\n const depth = parents.length;\n if (item.items?.length) {\n children = (\n <RenderRecursively\n data={data}\n items={item.items}\n render={Render}\n getItemKey={getItemKey}\n parents={[...parents, item]}\n />\n );\n }\n\n return (\n <Render\n key={getItemKey ? getItemKey(item) : `${depth}-${index}`}\n // typecast since it should be undefined in renderer as well?\n data={data}\n item={item}\n parents={parents}\n >\n {children}\n </Render>\n );\n })}\n </>\n );\n}\n"],"names":["RenderRecursively","props","data","items","render","Render","getItemKey","parents","map","item","index","children","depth","length"],"mappings":"AAAA,oDAAoD;;AA2EpD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyFC,GACD,OAAO,SAASA,kBACdC,KAAyC;IAEzC,MAAM,EAAEC,IAAI,EAAEC,KAAK,EAAEC,QAAQC,MAAM,EAAEC,UAAU,EAAEC,UAAU,EAAE,EAAE,GAAGN;IAElE,qBACE;kBACGE,MAAMK,GAAG,CAAC,CAACC,MAAMC;YAChB,IAAIC;YACJ,MAAMC,QAAQL,QAAQM,MAAM;YAC5B,IAAIJ,KAAKN,KAAK,EAAEU,QAAQ;gBACtBF,yBACE,KAACX;oBACCE,MAAMA;oBACNC,OAAOM,KAAKN,KAAK;oBACjBC,QAAQC;oBACRC,YAAYA;oBACZC,SAAS;2BAAIA;wBAASE;qBAAK;;YAGjC;YAEA,qBACE,KAACJ;gBAEC,6DAA6D;gBAC7DH,MAAMA;gBACNO,MAAMA;gBACNF,SAASA;0BAERI;eANIL,aAAaA,WAAWG,QAAQ,CAAC,EAAEG,MAAM,CAAC,EAAEF,MAAM,CAAC;QAS9D;;AAGN"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/utils/alphaNumericSort.ts"],"sourcesContent":["import type { TextExtractor } from \"../types.js\";\n\nconst identity = <T>(item: T): string => {\n if (typeof item === \"string\") {\n return item;\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n throw new Error(\n \"A `TextExtractor` must be provided to `alphaNumericSort` for lists that do not contain strings\"\n );\n }\n\n return \"\";\n};\n\n/**\n * The default `Intl.Collator` that should be used for sorting large lists.\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/localeCompare#performance\n * @remarks \\@since 6.0.0\n */\nexport const DEFAULT_COLLATOR = new Intl.Collator(\"en-US\", {\n numeric: true,\n caseFirst: \"upper\",\n});\n\n/** @remarks \\@since 6.0.0 */\nexport interface AlphaNumericSortOptions<T> {\n /**\n * The extractor is only required when the list of items are not strings.\n *\n * @example\n * Simple Example\n * ```ts\n * interface Item {\n * name: string;\n * }\n *\n * const items: Item[] = [{ name: 'Hello' }, { name: 'World' }];\n *\n * `alphaNumericSort(items, {\n * extractor: item => item.name,\n * })`\n * ```\n *\n * @remarks\n * For javascript developers, this will throw an error in dev mode if an\n * extractor is not provided for non-string lists.\n *\n * @defaultValue `typeof item === \"string\" ? item : \"\"`\n */\n extractor?: TextExtractor<T>;\n\n /**\n * A custom compare function for sorting the list. This should really only be\n * provided if the language for your app is not `\"en-US\"` or you'd like to\n * provide some custom sorting options.\n *\n * @example\n * Custom Compare using Intl.Collator\n * ```ts\n * const collator = new Intl.Collator(\"en-US\", {\n * numeric: false,\n * caseFirst: \"lower\",\n * usage: \"search\",\n * });\n *\n * alphaNumericSort(items, {\n * compare: collator.compare,\n * })\n * ```\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/Collator/Collator\n * @defaultValue `new Intl.Collator(\"en-US\", { numeric: true, caseFirst: \"upper\" }).compare`\n */\n compare?(a: string, b: string): number;\n\n /**\n * Setting this to `true` will return the list in descending order instead of\n * ascending.\n *\n * @defaultValue `false`\n */\n descending?: boolean;\n}\n\n/**\n * @example\n * Simple Example\n * ```ts\n * const items = [\"World\", \"Hello\"];\n *\n * const sorted = alphaNumericSort(items);\n * // sorted == [\"Hello\", \"World\"]\n * ```\n *\n * @param list - The list of strings to sort\n * @returns a new sorted list\n */\nexport function alphaNumericSort<T extends string>(\n list: readonly T[],\n options?: Omit<AlphaNumericSortOptions<T>, \"extractor\">\n): readonly T[];\n/**\n * @example\n * Simple Example\n * ```ts\n * interface Item {\n * name: string;\n * }\n *\n * const items: Item[] = [{ name: \"World\" }, { name: \"Hello\" }];\n *\n * const sorted = alphaNumericSort(items, {\n * extractor: item => item.name,\n * });\n * // sorted == [{ name: \"Hello\" }, { name: \"World\" }]\n * ```\n *\n * @param list - The list of items to sort\n * @returns a new sorted list\n */\nexport function alphaNumericSort<T>(\n list: readonly T[],\n options: AlphaNumericSortOptions<T> & { extractor: TextExtractor<T> }\n): readonly T[];\nexport function alphaNumericSort<T>(\n list: readonly T[],\n options: AlphaNumericSortOptions<T> = {}\n): readonly T[] {\n const {\n compare = DEFAULT_COLLATOR.compare,\n extractor = identity,\n descending = false,\n } = options;\n\n const sorted = list.slice();\n sorted.sort((a, b) => {\n const aValue = extractor(a);\n const bValue = extractor(b);\n\n const value1 = descending ? bValue : aValue;\n const value2 = descending ? aValue : bValue;\n\n return compare(value1, value2);\n });\n\n return sorted;\n}\n"],"names":["identity","item","process","env","NODE_ENV","Error","DEFAULT_COLLATOR","Intl","Collator","numeric","caseFirst","alphaNumericSort","list","options","compare","extractor","descending","sorted","slice","sort","a","b","aValue","bValue","value1","value2"],"mappings":"AAEA,MAAMA,WAAW,CAAIC;IACnB,IAAI,OAAOA,SAAS,UAAU;QAC5B,OAAOA;IACT;IAEA,IAAIC,QAAQC,GAAG,CAACC,QAAQ,KAAK,cAAc;QACzC,MAAM,IAAIC,MACR;IAEJ;IAEA,OAAO;AACT;AAEA;;;;;CAKC,GACD,OAAO,MAAMC,mBAAmB,IAAIC,KAAKC,QAAQ,CAAC,SAAS;IACzDC,SAAS;IACTC,WAAW;AACb,GAAG;AAsGH,OAAO,SAASC,iBACdC,IAAkB,EAClBC,UAAsC,CAAC,CAAC;IAExC,MAAM,EACJC,UAAUR,iBAAiBQ,OAAO,EAClCC,YAAYf,QAAQ,EACpBgB,aAAa,KAAK,EACnB,GAAGH;IAEJ,MAAMI,SAASL,KAAKM,KAAK;IACzBD,OAAOE,IAAI,CAAC,CAACC,GAAGC;QACd,MAAMC,SAASP,UAAUK;QACzB,MAAMG,SAASR,UAAUM;QAEzB,MAAMG,SAASR,aAAaO,SAASD;QACrC,MAAMG,SAAST,aAAaM,SAASC;QAErC,OAAOT,QAAQU,QAAQC;IACzB;IAEA,OAAOR;AACT"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/utils/applyRef.ts"],"sourcesContent":["import type { MutableRefObject, Ref } from \"react\";\n\n/**\n * A small utility function that allows me to apply a passed in ref along with\n * my own custom ref logic.\n *\n * @example\n * Simple Example\n * ```tsx\n * import { HTMLAttributes, forwardRef } from \"react\";\n * import { applyRef } from \"@react-md/core\";\n *\n * export type ExampleProps = HTMLAttributes<HTMLDivElement>;\n *\n * const Example = forwardRef<HTMLDivElement, ExampleProps>(function Example(props, ref) {\n * const refHandler = useCallback((instance: HTMLDivElement | null) => {\n * applyRef(instance, ref);\n * if (!instance) {\n * return;\n * }\n *\n * // do something with instance\n * });\n *\n * return <div ref={refHandler} />;\n * });\n * ```\n *\n * @param instance - The DOM Node instance\n * @param ref - The prop ref\n * @internal\n */\nexport function applyRef<E>(instance: E | null, ref: Ref<E> | undefined): void {\n if (!ref) {\n return;\n }\n\n if (typeof ref === \"function\") {\n ref(instance);\n } else if (typeof ref === \"object\") {\n (ref as MutableRefObject<E | null>).current = instance;\n }\n}\n"],"names":["applyRef","instance","ref","current"],"mappings":"AAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA6BC,GACD,OAAO,SAASA,SAAYC,QAAkB,EAAEC,GAAuB;IACrE,IAAI,CAACA,KAAK;QACR;IACF;IAEA,IAAI,OAAOA,QAAQ,YAAY;QAC7BA,IAAID;IACN,OAAO,IAAI,OAAOC,QAAQ,UAAU;QACjCA,IAAmCC,OAAO,GAAGF;IAChD;AACF"}