@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/tree/Tree.tsx"],"sourcesContent":["\"use client\";\nimport {\n type ComponentType,\n type HTMLAttributes,\n type ReactElement,\n type ReactNode,\n type Ref,\n} from \"react\";\nimport { type CustomLinkComponent } from \"../link/Link.js\";\nimport { List } from \"../list/List.js\";\nimport { KeyboardMovementProvider } from \"../movement/useKeyboardMovementProvider.js\";\nimport { type LabelRequiredForA11y } from \"../types.js\";\nimport { useEnsuredId } from \"../useEnsuredId.js\";\nimport {\n RenderRecursively,\n type RenderRecursiveItemsProps,\n} from \"../utils/RenderRecursively.js\";\nimport { identity } from \"../utils/identity.js\";\nimport { DefaultTreeItemRenderer } from \"./DefaultTreeItemRenderer.js\";\nimport { TreeProvider, type TreeExpansionMode } from \"./TreeProvider.js\";\nimport { tree } from \"./styles.js\";\nimport {\n type TreeData,\n type TreeItemNode,\n type TreeItemSorter,\n} from \"./types.js\";\nimport { type TreeExpansion } from \"./useTreeExpansion.js\";\nimport { useTreeItems } from \"./useTreeItems.js\";\nimport { useTreeMovement } from \"./useTreeMovement.js\";\nimport { type TreeSelection } from \"./useTreeSelection.js\";\n\ndeclare module \"react\" {\n interface CSSProperties {\n \"--rmd-tree-depth\"?: number;\n \"--rmd-tree-item-padding\"?: string | number;\n \"--rmd-tree-item-padding-base\"?: string | number;\n \"--rmd-tree-item-padding-incrementor\"?: string | number;\n }\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport type TreeHTMLAttributes = Omit<\n HTMLAttributes<HTMLUListElement>,\n \"role\" | \"tabIndex\" | \"children\"\n>;\n\n/**\n * @remarks\n * \\@since 6.0.0 There was a major API change and the `id` is now `optional`.\n * In addition, the following props were removed:\n * - `itemRenderer`\n * - `labelKey`\n * - `valueKey`\n * - `getItemLabel`\n * - `getItemValue`\n * - `getItemProps`\n */\nexport interface TreeProps<T extends TreeItemNode>\n extends TreeHTMLAttributes,\n TreeExpansion,\n TreeSelection {\n /** @see {@link TreeData} */\n data: TreeData<T>;\n\n /**\n * An optional ref to pass to the tree element.\n *\n * @remarks \\@since 6.0.0\n */\n treeRef?: Ref<HTMLUListElement>;\n\n /** @defaultValue `identity` */\n sort?: TreeItemSorter<T>;\n\n /**\n * Any nodes in the {@Link data} that have a `parentId` set to this value will\n * appear at the root of the tree.\n *\n * @defaultValue `null`\n */\n rootId?: string | null;\n\n /**\n * @defaultValue `\"auto\"`\n * @see {@link TreeExpansionMode}\n */\n expansionMode?: TreeExpansionMode;\n\n /**\n * Set this to `true` to display the expander icon to the left instead of the\n * right. This will also update the styles slightly so you can still provide a\n * `leftAddon`.\n *\n * @defaultValue `false`\n */\n expanderLeft?: boolean;\n\n /**\n * @defaultValue `getIcon(\"expander\")`\n */\n expanderIcon?: ReactNode;\n\n /**\n * Set this to `true` to disable the collapse transition for all tree items.\n *\n * @defaultValue `false`\n */\n disableTransition?: boolean;\n\n /**\n * Set this to `true` if the collapsed tree items should be removed from the\n * DOM instead of hidden using `display: none`. This _might_ improve\n * performance for large trees.\n *\n * @defaultValue `false`\n */\n temporaryChildItems?: boolean;\n\n /**\n * @example\n * Custom Tree Item Renderer\n * ```tsx\n * import {\n * TreeItem,\n * useKeyboardMovementContext,\n * useTreeContext,\n * type RenderRecursiveItemsProps,\n * } from \"@react-md/core\";\n * import FolderIcon from \"@react-md/material-icons/FolderIcon\";\n * import FolderOpenIcon from \"@react-md/material-icons/FolderOpenIcon\";\n * import { type ReactElement } from \"react\";\n *\n * export function CustomTreeItem(props: TreeItemRendererProps): ReactElement {\n * const { item, ...remaining } = props;\n * const id = useId();\n * const { itemId } = item;\n * const {\n * data,\n * expandedIds,\n * selectedIds,\n * toggleTreeItemExpansion,\n * toggleTreeItemSelection,\n * } = useTreeContext()\n * const { activeDescendantId } = useKeyboardMovementContext();\n *\n * const focused = id === activeDescendantId;\n * const expanded = expandedIds.has(itemId);\n * const selected = selectedIds.has(itemId);\n * const children = ...; // do whatever\n *\n * return (\n * <TreeItem\n * {...remaining}\n * id={id}\n * itemId={itemId}\n * leftAddon={expanded ? <FolderOpenIcon /> : <FolderIcon />}\n * >\n * {children}\n * </TreeItem>\n * );\n * }\n * ```\n *\n * @see {@link DefaultTreeItemRenderer}\n * @defaultValue `DefaultTreeItemRenderer`\n */\n renderer?: ComponentType<RenderRecursiveItemsProps<T, TreeData<T>>>;\n\n /**\n * The link component to use for any tree item nodes that have a `to` or\n * `href`.\n *\n * @see {@link CustomLinkComponent}\n * @defaultValue `Link`\n */\n linkComponent?: CustomLinkComponent;\n}\n\n/**\n * **Client Component**\n *\n * @example\n * Simple Tree\n * ```tsx\n * import type { TreeData } from \"@react-md/core\";\n * import { Tree, useTree } from \"@react-md/core\";\n * import type { ReactElement } from \"react\";\n *\n * const data: TreeData = {\n * \"item-1\": {\n * itemId: \"item-1\",\n * parentId: null,\n * name: \"Root Level Item 1\",\n * },\n * \"item-2\": {\n * itemId: \"item-2\",\n * parentId: \"item-1\",\n * name: \"A child for the first item\",\n * },\n * \"item-3\": {\n * itemId: \"item-3\",\n * parentId: \"item-1\",\n * children: \"Another child for the first item\",\n * },\n * };\n *\n * function Example(): ReactElement {\n * const tree = useTree({\n * // can enable multiple selected items\n * // multiSelect: true,\n *\n * // can set default expanded and selected items\n * // defaultSelectedIds: [\"item-1\"],\n * // defaultExpandedIds: [\"item-1\"],\n * });\n *\n * return (\n * <Tree\n * {...tree}\n * aria-label=\"Tree\"\n * data={data}\n * />\n * );\n * }\n * ```\n *\n * @see {@link TreeProps.renderer} for a custom tree item example.\n *\n * @remarks\n * \\@since 6.0.0 There was a major API change and the `id` is now `optional`.\n * In addition, the following props were removed:\n * - `itemRenderer`\n * - `labelKey`\n * - `valueKey`\n * - `getItemLabel`\n * - `getItemValue`\n * - `getItemProps`\n */\nexport function Tree<T extends TreeItemNode>(\n props: LabelRequiredForA11y<TreeProps<T>>\n): ReactElement {\n const {\n id,\n data,\n sort = identity,\n rootId = null,\n treeRef,\n className,\n expandedIds,\n selectedIds,\n toggleTreeItemSelection,\n selectMultipleTreeItems,\n toggleTreeItemExpansion,\n expandMultipleTreeItems,\n onClick,\n onFocus,\n onKeyDown,\n renderer: TreeItemRenderer = DefaultTreeItemRenderer,\n multiSelect = false,\n expansionMode = \"auto\",\n expanderIcon,\n expanderLeft = false,\n linkComponent = \"a\",\n disableTransition = false,\n temporaryChildItems = false,\n ...remaining\n } = props;\n const treeId = useEnsuredId(id, \"tree\");\n const { items, treeItemChildIds } = useTreeItems({\n data,\n sort,\n rootId,\n });\n\n const { metadataLookup, movementContext, movementProps } = useTreeMovement({\n onClick,\n onFocus,\n onKeyDown,\n data,\n expandedIds,\n selectedIds,\n treeItemChildIds,\n toggleTreeItemExpansion,\n expandMultipleTreeItems,\n });\n\n return (\n <TreeProvider\n data={data}\n rootId={rootId}\n multiSelect={multiSelect}\n linkComponent={linkComponent}\n selectedIds={selectedIds}\n expandedIds={expandedIds}\n expanderIcon={expanderIcon}\n expanderLeft={expanderLeft}\n expansionMode={expansionMode}\n metadataLookup={metadataLookup}\n disableTransition={disableTransition}\n temporaryChildItems={temporaryChildItems}\n toggleTreeItemSelection={toggleTreeItemSelection}\n toggleTreeItemExpansion={toggleTreeItemExpansion}\n selectMultipleTreeItems={selectMultipleTreeItems}\n expandMultipleTreeItems={expandMultipleTreeItems}\n >\n <KeyboardMovementProvider value={movementContext}>\n <List\n {...remaining}\n {...movementProps}\n id={treeId}\n ref={treeRef}\n role=\"tree\"\n tabIndex={0}\n className={tree({ className })}\n >\n <RenderRecursively\n items={items}\n getItemKey={(item) => item.itemId}\n render={TreeItemRenderer}\n />\n </List>\n </KeyboardMovementProvider>\n </TreeProvider>\n );\n}\n"],"names":["List","KeyboardMovementProvider","useEnsuredId","RenderRecursively","identity","DefaultTreeItemRenderer","TreeProvider","tree","useTreeItems","useTreeMovement","Tree","props","id","data","sort","rootId","treeRef","className","expandedIds","selectedIds","toggleTreeItemSelection","selectMultipleTreeItems","toggleTreeItemExpansion","expandMultipleTreeItems","onClick","onFocus","onKeyDown","renderer","TreeItemRenderer","multiSelect","expansionMode","expanderIcon","expanderLeft","linkComponent","disableTransition","temporaryChildItems","remaining","treeId","items","treeItemChildIds","metadataLookup","movementContext","movementProps","value","ref","role","tabIndex","getItemKey","item","itemId","render"],"mappings":"AAAA;;AASA,SAASA,IAAI,QAAQ,kBAAkB;AACvC,SAASC,wBAAwB,QAAQ,6CAA6C;AAEtF,SAASC,YAAY,QAAQ,qBAAqB;AAClD,SACEC,iBAAiB,QAEZ,gCAAgC;AACvC,SAASC,QAAQ,QAAQ,uBAAuB;AAChD,SAASC,uBAAuB,QAAQ,+BAA+B;AACvE,SAASC,YAAY,QAAgC,oBAAoB;AACzE,SAASC,IAAI,QAAQ,cAAc;AAOnC,SAASC,YAAY,QAAQ,oBAAoB;AACjD,SAASC,eAAe,QAAQ,uBAAuB;AAwJvD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2DC,GACD,OAAO,SAASC,KACdC,KAAyC;IAEzC,MAAM,EACJC,EAAE,EACFC,IAAI,EACJC,OAAOV,QAAQ,EACfW,SAAS,IAAI,EACbC,OAAO,EACPC,SAAS,EACTC,WAAW,EACXC,WAAW,EACXC,uBAAuB,EACvBC,uBAAuB,EACvBC,uBAAuB,EACvBC,uBAAuB,EACvBC,OAAO,EACPC,OAAO,EACPC,SAAS,EACTC,UAAUC,mBAAmBvB,uBAAuB,EACpDwB,cAAc,KAAK,EACnBC,gBAAgB,MAAM,EACtBC,YAAY,EACZC,eAAe,KAAK,EACpBC,gBAAgB,GAAG,EACnBC,oBAAoB,KAAK,EACzBC,sBAAsB,KAAK,EAC3B,GAAGC,WACJ,GAAGzB;IACJ,MAAM0B,SAASnC,aAAaU,IAAI;IAChC,MAAM,EAAE0B,KAAK,EAAEC,gBAAgB,EAAE,GAAG/B,aAAa;QAC/CK;QACAC;QACAC;IACF;IAEA,MAAM,EAAEyB,cAAc,EAAEC,eAAe,EAAEC,aAAa,EAAE,GAAGjC,gBAAgB;QACzEe;QACAC;QACAC;QACAb;QACAK;QACAC;QACAoB;QACAjB;QACAC;IACF;IAEA,qBACE,KAACjB;QACCO,MAAMA;QACNE,QAAQA;QACRc,aAAaA;QACbI,eAAeA;QACfd,aAAaA;QACbD,aAAaA;QACba,cAAcA;QACdC,cAAcA;QACdF,eAAeA;QACfU,gBAAgBA;QAChBN,mBAAmBA;QACnBC,qBAAqBA;QACrBf,yBAAyBA;QACzBE,yBAAyBA;QACzBD,yBAAyBA;QACzBE,yBAAyBA;kBAEzB,cAAA,KAACtB;YAAyB0C,OAAOF;sBAC/B,cAAA,KAACzC;gBACE,GAAGoC,SAAS;gBACZ,GAAGM,aAAa;gBACjB9B,IAAIyB;gBACJO,KAAK5B;gBACL6B,MAAK;gBACLC,UAAU;gBACV7B,WAAWV,KAAK;oBAAEU;gBAAU;0BAE5B,cAAA,KAACd;oBACCmC,OAAOA;oBACPS,YAAY,CAACC,OAASA,KAAKC,MAAM;oBACjCC,QAAQtB;;;;;AAMpB"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/TreeGroup.tsx"],"sourcesContent":["\"use client\";\nimport { forwardRef, type CSSProperties, type ReactNode } from \"react\";\nimport { List, type ListProps } from \"../list/List.js\";\nimport { useCollapseTransition } from \"../transition/useCollapseTransition.js\";\nimport { useTreeContext } from \"./TreeProvider.js\";\nimport { treeGroup } from \"./styles.js\";\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface OverridableTreeGroupProps extends ListProps {\n /** @defaultValue `false` */\n temporary?: boolean;\n\n /** @defaultValue `false` */\n disableTransition?: boolean;\n}\n\n/**\n * @internal\n * @remarks \\@since 6.0.0\n */\nexport interface TreeGroupProps extends OverridableTreeGroupProps {\n children: ReactNode;\n depth: number;\n collapsed: boolean;\n}\n\n/**\n * **Client Component**\n *\n * @internal\n * @remarks \\@since 6.0.0 Removed the collapse options and is no longer a\n * \"public\" component.\n */\nexport const TreeGroup = forwardRef<HTMLUListElement, TreeGroupProps>(\n function TreeGroup(props, ref) {\n const {\n className,\n collapsed,\n depth,\n onClick,\n onMouseDown,\n children,\n temporary: propTemporary,\n disableTransition = false,\n ...remaining\n } = props;\n\n const style: CSSProperties = {\n ...remaining.style,\n \"--rmd-tree-depth\": depth,\n };\n\n const { temporaryChildItems } = useTreeContext();\n const temporary = propTemporary ?? temporaryChildItems;\n\n const { elementProps, rendered } = useCollapseTransition({\n style,\n nodeRef: ref,\n enter: !disableTransition,\n exit: !disableTransition,\n transitionIn: !collapsed,\n temporary,\n className: treeGroup({ className }),\n });\n\n if (!rendered || !children) {\n return null;\n }\n\n return (\n <List\n {...remaining}\n onClick={(event) => {\n onClick?.(event);\n // always stop propagation for click events and mousedown for groups\n // so that the parent child item's click and mousedown events aren't\n // also fired while there are disabled child elementsS or\n // non-interactable (like dividers or subheader)\n event.stopPropagation();\n }}\n onMouseDown={(event) => {\n onMouseDown?.(event);\n event.stopPropagation();\n }}\n {...elementProps}\n role=\"group\"\n >\n {children}\n </List>\n );\n }\n);\n"],"names":["forwardRef","List","useCollapseTransition","useTreeContext","treeGroup","TreeGroup","props","ref","className","collapsed","depth","onClick","onMouseDown","children","temporary","propTemporary","disableTransition","remaining","style","temporaryChildItems","elementProps","rendered","nodeRef","enter","exit","transitionIn","event","stopPropagation","role"],"mappings":"AAAA;;AACA,SAASA,UAAU,QAA4C,QAAQ;AACvE,SAASC,IAAI,QAAwB,kBAAkB;AACvD,SAASC,qBAAqB,QAAQ,yCAAyC;AAC/E,SAASC,cAAc,QAAQ,oBAAoB;AACnD,SAASC,SAAS,QAAQ,cAAc;AAuBxC;;;;;;CAMC,GACD,OAAO,MAAMC,0BAAYL,WACvB,SAASK,UAAUC,KAAK,EAAEC,GAAG;IAC3B,MAAM,EACJC,SAAS,EACTC,SAAS,EACTC,KAAK,EACLC,OAAO,EACPC,WAAW,EACXC,QAAQ,EACRC,WAAWC,aAAa,EACxBC,oBAAoB,KAAK,EACzB,GAAGC,WACJ,GAAGX;IAEJ,MAAMY,QAAuB;QAC3B,GAAGD,UAAUC,KAAK;QAClB,oBAAoBR;IACtB;IAEA,MAAM,EAAES,mBAAmB,EAAE,GAAGhB;IAChC,MAAMW,YAAYC,iBAAiBI;IAEnC,MAAM,EAAEC,YAAY,EAAEC,QAAQ,EAAE,GAAGnB,sBAAsB;QACvDgB;QACAI,SAASf;QACTgB,OAAO,CAACP;QACRQ,MAAM,CAACR;QACPS,cAAc,CAAChB;QACfK;QACAN,WAAWJ,UAAU;YAAEI;QAAU;IACnC;IAEA,IAAI,CAACa,YAAY,CAACR,UAAU;QAC1B,OAAO;IACT;IAEA,qBACE,KAACZ;QACE,GAAGgB,SAAS;QACbN,SAAS,CAACe;YACRf,UAAUe;YACV,oEAAoE;YACpE,oEAAoE;YACpE,yDAAyD;YACzD,gDAAgD;YAChDA,MAAMC,eAAe;QACvB;QACAf,aAAa,CAACc;YACZd,cAAcc;YACdA,MAAMC,eAAe;QACvB;QACC,GAAGP,YAAY;QAChBQ,MAAK;kBAEJf;;AAGP,GACA"}
@@ -0,0 +1,173 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { useEffect } from "react";
4
+ import { useElementInteraction } from "../interaction/useElementInteraction.js";
5
+ import { useHigherContrastChildren } from "../interaction/useHigherContrastChildren.js";
6
+ import { ListItemChildren } from "../list/ListItemChildren.js";
7
+ import { useKeyboardMovementContext } from "../movement/useKeyboardMovementProvider.js";
8
+ import { useEnsuredId } from "../useEnsuredId.js";
9
+ import { TreeGroup } from "./TreeGroup.js";
10
+ import { TreeItemExpander } from "./TreeItemExpander.js";
11
+ import { useTreeContext } from "./TreeProvider.js";
12
+ import { treeItem, treeItemContent, treeItemMedia } from "./styles.js";
13
+ /**
14
+ * **Client Component**
15
+ *
16
+ * @see {@link https://www.w3.org/WAI/ARIA/apg/patterns/treeview/}
17
+ * @remarks
18
+ * \@since 6.0.0 The wrapping `<li>` element will always be `role="none"` and
19
+ * the `<span>` or `<a>` will gain the `role="treeitem"` instead. This makes it
20
+ * easier to pass event handlers because of the nested behavior of tree items.
21
+ * \@since 6.0.0 No longer provides the `aria-level`, `aria-setsize` and
22
+ * `aria-posinset` attributes and allows the browser to compute them instead.
23
+ */ export function TreeItem(props) {
24
+ const { id: propId, depth, liProps, disabled = false, disabledOpacity = false, groupProps, children: propChildren, className, itemId, leftAddon, leftAddonType: propLeftAddonType, leftAddonPosition, leftAddonClassName, leftAddonForceWrap, rightAddon, rightAddonType, rightAddonPosition, rightAddonClassName, rightAddonForceWrap, disableTextChildren, disableLeftAddonCenteredMedia: propDisableLeftAddonCenteredMedia, disableRightAddonCenteredMedia, textProps, textClassName, primaryText, secondaryText, secondaryTextProps, secondaryTextClassName, multiline, childItems, contentClassName, temporaryChildItems, disableTransition: propDisableTransition, onBlur, onClick, onKeyDown, onKeyUp, onMouseDown, onMouseUp, onMouseLeave, onDragStart, onTouchStart, onTouchEnd, onTouchMove, contentRef, ...remaining } = props;
25
+ const id = useEnsuredId(propId, "tree-item");
26
+ const children = useHigherContrastChildren(propChildren);
27
+ if (disabled) {
28
+ // you can't really disable a link other than removing the href, so
29
+ // unset these props
30
+ remaining.to = undefined;
31
+ remaining.href = undefined;
32
+ }
33
+ const { expandedIds, selectedIds, expanderLeft, expansionMode, metadataLookup, linkComponent: Link, toggleTreeItemSelection, toggleTreeItemExpansion, disableTransition: contextDisableTransition } = useTreeContext();
34
+ const { activeDescendantId } = useKeyboardMovementContext();
35
+ const isLeafNode = !childItems;
36
+ const focused = activeDescendantId === id;
37
+ const expanded = expandedIds.has(itemId);
38
+ const selected = selectedIds.has(itemId);
39
+ const disableTransition = propDisableTransition ?? contextDisableTransition;
40
+ useEffect(()=>{
41
+ const lookup = metadataLookup.current;
42
+ lookup.expandable[itemId] = !isLeafNode;
43
+ lookup.disabledItems[itemId] = disabled;
44
+ lookup.elementToItem[id] = itemId;
45
+ lookup.itemToElement[itemId] = id;
46
+ return ()=>{
47
+ delete lookup.disabledItems[itemId];
48
+ delete lookup.expandable[itemId];
49
+ delete lookup.elementToItem[id];
50
+ delete lookup.itemToElement[itemId];
51
+ };
52
+ }, [
53
+ id,
54
+ metadataLookup,
55
+ itemId,
56
+ isLeafNode,
57
+ disabled,
58
+ depth
59
+ ]);
60
+ const { pressedClassName, ripples, handlers } = useElementInteraction({
61
+ onBlur,
62
+ onClick (event) {
63
+ onClick?.(event);
64
+ toggleTreeItemSelection(itemId);
65
+ if (!isLeafNode && expansionMode !== "manual") {
66
+ toggleTreeItemExpansion(itemId);
67
+ }
68
+ },
69
+ onKeyDown,
70
+ onKeyUp,
71
+ onMouseDown,
72
+ onMouseUp,
73
+ onMouseLeave,
74
+ onDragStart,
75
+ onTouchStart,
76
+ onTouchEnd,
77
+ onTouchMove,
78
+ disabled
79
+ });
80
+ const isLink = !!(remaining.to || remaining.href);
81
+ // cheating a bit so there are type errors around the event handlers
82
+ const ContentComponent = isLink ? Link : "span";
83
+ const leftAddonType = propLeftAddonType ?? (expanderLeft && leftAddon) ? "media" : undefined;
84
+ const isMediaLeftAddon = typeof propLeftAddonType === "undefined" && leftAddonType === "media";
85
+ const disableLeftAddonCenteredMedia = propDisableLeftAddonCenteredMedia ?? isMediaLeftAddon;
86
+ return /*#__PURE__*/ _jsxs("li", {
87
+ ...liProps,
88
+ role: "none",
89
+ className: treeItem({
90
+ className,
91
+ expander: !!childItems,
92
+ expanderLeft
93
+ }),
94
+ children: [
95
+ /*#__PURE__*/ _jsxs(ContentComponent, {
96
+ ...remaining,
97
+ // nodes with children should always apply the `aria-expanded` to show
98
+ // that it is expandable while leaf nodes should remain omitted
99
+ "aria-expanded": isLeafNode ? undefined : expanded,
100
+ "aria-selected": selected,
101
+ "aria-disabled": disabled || undefined,
102
+ id: id,
103
+ ref: contentRef,
104
+ role: "treeitem",
105
+ tabIndex: -1,
106
+ ...handlers,
107
+ className: treeItemContent({
108
+ link: isLink,
109
+ focused,
110
+ selected,
111
+ disabled,
112
+ disabledOpacity,
113
+ className: contentClassName,
114
+ pressedClassName
115
+ }),
116
+ children: [
117
+ /*#__PURE__*/ _jsx(ListItemChildren, {
118
+ multiline: multiline,
119
+ textClassName: textClassName,
120
+ secondaryTextClassName: secondaryTextClassName,
121
+ disableTextChildren: disableTextChildren,
122
+ primaryText: primaryText,
123
+ textProps: textProps,
124
+ secondaryText: secondaryText,
125
+ secondaryTextProps: secondaryTextProps,
126
+ leftAddon: /*#__PURE__*/ _jsx(TreeItemExpander, {
127
+ isLeft: true,
128
+ itemId: itemId,
129
+ addon: leftAddon,
130
+ expanded: expanded,
131
+ disabled: disabled,
132
+ isLeafNode: isLeafNode
133
+ }),
134
+ leftAddonType: leftAddonType,
135
+ leftAddonPosition: leftAddonPosition,
136
+ leftAddonClassName: treeItemMedia({
137
+ isLeafNode,
138
+ isMediaLeftAddon,
139
+ className: leftAddonClassName
140
+ }),
141
+ leftAddonForceWrap: leftAddonForceWrap,
142
+ rightAddon: /*#__PURE__*/ _jsx(TreeItemExpander, {
143
+ itemId: itemId,
144
+ addon: rightAddon,
145
+ expanded: expanded,
146
+ disabled: disabled,
147
+ isLeafNode: isLeafNode
148
+ }),
149
+ rightAddonType: rightAddonType,
150
+ rightAddonPosition: rightAddonPosition,
151
+ rightAddonClassName: rightAddonClassName,
152
+ rightAddonForceWrap: rightAddonForceWrap,
153
+ disableLeftAddonCenteredMedia: disableLeftAddonCenteredMedia,
154
+ disableRightAddonCenteredMedia: disableRightAddonCenteredMedia,
155
+ children: children
156
+ }),
157
+ ripples
158
+ ]
159
+ }),
160
+ /*#__PURE__*/ _jsx(TreeGroup, {
161
+ id: `${id}-group`,
162
+ temporary: temporaryChildItems,
163
+ disableTransition: disableTransition,
164
+ ...groupProps,
165
+ depth: depth + 1,
166
+ collapsed: isLeafNode || !expanded,
167
+ children: childItems
168
+ })
169
+ ]
170
+ });
171
+ }
172
+
173
+ //# sourceMappingURL=TreeItem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/TreeItem.tsx"],"sourcesContent":["\"use client\";\nimport {\n useEffect,\n type HTMLAttributes,\n type ReactElement,\n type ReactNode,\n type Ref,\n} from \"react\";\nimport { useElementInteraction } from \"../interaction/useElementInteraction.js\";\nimport { useHigherContrastChildren } from \"../interaction/useHigherContrastChildren.js\";\nimport { ListItemChildren } from \"../list/ListItemChildren.js\";\nimport { useKeyboardMovementContext } from \"../movement/useKeyboardMovementProvider.js\";\nimport { type PropsWithRef } from \"../types.js\";\nimport { useEnsuredId } from \"../useEnsuredId.js\";\nimport { TreeGroup, type OverridableTreeGroupProps } from \"./TreeGroup.js\";\nimport { TreeItemExpander } from \"./TreeItemExpander.js\";\nimport { useTreeContext } from \"./TreeProvider.js\";\nimport { treeItem, treeItemContent, treeItemMedia } from \"./styles.js\";\nimport { type DefaultTreeItemNode } from \"./types.js\";\n\n/**\n * @remarks \\@since 6.0.0 Added the `groupProps` prop.\n */\nexport interface TreeItemProps\n extends Omit<DefaultTreeItemNode, \"parentId\">,\n HTMLAttributes<HTMLLIElement> {\n /**\n * @defaultValue `\"tree-item-\" + useId()`\n */\n id?: string;\n\n /**\n * This is used to set the `--rmd-tree-depth` CSS variable which allows the\n * padding to increase for each nested tree.\n */\n depth: number;\n\n /**\n * Any additional props that should be passed to the surrounding `<li>`\n * element. The top-level props are passed to the `<span>` or `<a>` element\n * instead.\n */\n liProps?: PropsWithRef<HTMLAttributes<HTMLLIElement>, HTMLLIElement>;\n\n /**\n * Any additional props to pass to the `TreeGroup` component.\n */\n groupProps?: PropsWithRef<OverridableTreeGroupProps, HTMLUListElement>;\n\n /**\n * This should normally be the text/content to display within the tree item\n * and should **not** include nested trees.\n */\n children?: ReactNode;\n\n /**\n * The nested tree items to render within a `TreeGroup`.\n */\n childItems?: ReactNode;\n\n /** @defaultValue `false` */\n disableTransition?: boolean;\n\n /**\n * This ref is applied to the `<span>` or `<a>` element and can be used to\n * implement drag and drop behavior.\n */\n contentRef?: Ref<HTMLElement>;\n\n /**\n * Set this to `true` if the {@link childItems} should not be rendered while\n * collapsed.\n *\n * @defaultValue `false`\n */\n temporaryChildItems?: boolean;\n}\n\n/**\n * **Client Component**\n *\n * @see {@link https://www.w3.org/WAI/ARIA/apg/patterns/treeview/}\n * @remarks\n * \\@since 6.0.0 The wrapping `<li>` element will always be `role=\"none\"` and\n * the `<span>` or `<a>` will gain the `role=\"treeitem\"` instead. This makes it\n * easier to pass event handlers because of the nested behavior of tree items.\n * \\@since 6.0.0 No longer provides the `aria-level`, `aria-setsize` and\n * `aria-posinset` attributes and allows the browser to compute them instead.\n */\nexport function TreeItem(props: TreeItemProps): ReactElement {\n const {\n id: propId,\n depth,\n liProps,\n disabled = false,\n disabledOpacity = false,\n groupProps,\n children: propChildren,\n className,\n itemId,\n leftAddon,\n leftAddonType: propLeftAddonType,\n leftAddonPosition,\n leftAddonClassName,\n leftAddonForceWrap,\n rightAddon,\n rightAddonType,\n rightAddonPosition,\n rightAddonClassName,\n rightAddonForceWrap,\n disableTextChildren,\n disableLeftAddonCenteredMedia: propDisableLeftAddonCenteredMedia,\n disableRightAddonCenteredMedia,\n textProps,\n textClassName,\n primaryText,\n secondaryText,\n secondaryTextProps,\n secondaryTextClassName,\n multiline,\n childItems,\n contentClassName,\n temporaryChildItems,\n disableTransition: propDisableTransition,\n onBlur,\n onClick,\n onKeyDown,\n onKeyUp,\n onMouseDown,\n onMouseUp,\n onMouseLeave,\n onDragStart,\n onTouchStart,\n onTouchEnd,\n onTouchMove,\n contentRef,\n ...remaining\n } = props;\n\n const id = useEnsuredId(propId, \"tree-item\");\n const children = useHigherContrastChildren(propChildren);\n if (disabled) {\n // you can't really disable a link other than removing the href, so\n // unset these props\n remaining.to = undefined;\n remaining.href = undefined;\n }\n\n const {\n expandedIds,\n selectedIds,\n expanderLeft,\n expansionMode,\n metadataLookup,\n linkComponent: Link,\n toggleTreeItemSelection,\n toggleTreeItemExpansion,\n disableTransition: contextDisableTransition,\n } = useTreeContext();\n const { activeDescendantId } = useKeyboardMovementContext();\n\n const isLeafNode = !childItems;\n const focused = activeDescendantId === id;\n const expanded = expandedIds.has(itemId);\n const selected = selectedIds.has(itemId);\n const disableTransition = propDisableTransition ?? contextDisableTransition;\n\n useEffect(() => {\n const lookup = metadataLookup.current;\n lookup.expandable[itemId] = !isLeafNode;\n lookup.disabledItems[itemId] = disabled;\n lookup.elementToItem[id] = itemId;\n lookup.itemToElement[itemId] = id;\n\n return () => {\n delete lookup.disabledItems[itemId];\n delete lookup.expandable[itemId];\n delete lookup.elementToItem[id];\n delete lookup.itemToElement[itemId];\n };\n }, [id, metadataLookup, itemId, isLeafNode, disabled, depth]);\n\n const { pressedClassName, ripples, handlers } =\n useElementInteraction<HTMLLIElement>({\n onBlur,\n onClick(event) {\n onClick?.(event);\n toggleTreeItemSelection(itemId);\n if (!isLeafNode && expansionMode !== \"manual\") {\n toggleTreeItemExpansion(itemId);\n }\n },\n onKeyDown,\n onKeyUp,\n onMouseDown,\n onMouseUp,\n onMouseLeave,\n onDragStart,\n onTouchStart,\n onTouchEnd,\n onTouchMove,\n disabled,\n });\n\n const isLink = !!(remaining.to || remaining.href);\n\n // cheating a bit so there are type errors around the event handlers\n const ContentComponent = (isLink ? Link : \"span\") as \"span\";\n const leftAddonType =\n propLeftAddonType ?? (expanderLeft && leftAddon) ? \"media\" : undefined;\n const isMediaLeftAddon =\n typeof propLeftAddonType === \"undefined\" && leftAddonType === \"media\";\n const disableLeftAddonCenteredMedia =\n propDisableLeftAddonCenteredMedia ?? isMediaLeftAddon;\n\n return (\n <li\n {...liProps}\n role=\"none\"\n className={treeItem({\n className,\n expander: !!childItems,\n expanderLeft,\n })}\n >\n <ContentComponent\n {...remaining}\n // nodes with children should always apply the `aria-expanded` to show\n // that it is expandable while leaf nodes should remain omitted\n aria-expanded={isLeafNode ? undefined : expanded}\n aria-selected={selected}\n aria-disabled={disabled || undefined}\n id={id}\n ref={contentRef}\n role=\"treeitem\"\n tabIndex={-1}\n {...handlers}\n className={treeItemContent({\n link: isLink,\n focused,\n selected,\n disabled,\n disabledOpacity,\n className: contentClassName,\n pressedClassName,\n })}\n >\n <ListItemChildren\n multiline={multiline}\n textClassName={textClassName}\n secondaryTextClassName={secondaryTextClassName}\n disableTextChildren={disableTextChildren}\n primaryText={primaryText}\n textProps={textProps}\n secondaryText={secondaryText}\n secondaryTextProps={secondaryTextProps}\n leftAddon={\n <TreeItemExpander\n isLeft\n itemId={itemId}\n addon={leftAddon}\n expanded={expanded}\n disabled={disabled}\n isLeafNode={isLeafNode}\n />\n }\n leftAddonType={leftAddonType}\n leftAddonPosition={leftAddonPosition}\n leftAddonClassName={treeItemMedia({\n isLeafNode,\n isMediaLeftAddon,\n className: leftAddonClassName,\n })}\n leftAddonForceWrap={leftAddonForceWrap}\n rightAddon={\n <TreeItemExpander\n itemId={itemId}\n addon={rightAddon}\n expanded={expanded}\n disabled={disabled}\n isLeafNode={isLeafNode}\n />\n }\n rightAddonType={rightAddonType}\n rightAddonPosition={rightAddonPosition}\n rightAddonClassName={rightAddonClassName}\n rightAddonForceWrap={rightAddonForceWrap}\n disableLeftAddonCenteredMedia={disableLeftAddonCenteredMedia}\n disableRightAddonCenteredMedia={disableRightAddonCenteredMedia}\n >\n {children}\n </ListItemChildren>\n {ripples}\n </ContentComponent>\n <TreeGroup\n id={`${id}-group`}\n temporary={temporaryChildItems}\n disableTransition={disableTransition}\n {...groupProps}\n depth={depth + 1}\n collapsed={isLeafNode || !expanded}\n >\n {childItems}\n </TreeGroup>\n </li>\n );\n}\n"],"names":["useEffect","useElementInteraction","useHigherContrastChildren","ListItemChildren","useKeyboardMovementContext","useEnsuredId","TreeGroup","TreeItemExpander","useTreeContext","treeItem","treeItemContent","treeItemMedia","TreeItem","props","id","propId","depth","liProps","disabled","disabledOpacity","groupProps","children","propChildren","className","itemId","leftAddon","leftAddonType","propLeftAddonType","leftAddonPosition","leftAddonClassName","leftAddonForceWrap","rightAddon","rightAddonType","rightAddonPosition","rightAddonClassName","rightAddonForceWrap","disableTextChildren","disableLeftAddonCenteredMedia","propDisableLeftAddonCenteredMedia","disableRightAddonCenteredMedia","textProps","textClassName","primaryText","secondaryText","secondaryTextProps","secondaryTextClassName","multiline","childItems","contentClassName","temporaryChildItems","disableTransition","propDisableTransition","onBlur","onClick","onKeyDown","onKeyUp","onMouseDown","onMouseUp","onMouseLeave","onDragStart","onTouchStart","onTouchEnd","onTouchMove","contentRef","remaining","to","undefined","href","expandedIds","selectedIds","expanderLeft","expansionMode","metadataLookup","linkComponent","Link","toggleTreeItemSelection","toggleTreeItemExpansion","contextDisableTransition","activeDescendantId","isLeafNode","focused","expanded","has","selected","lookup","current","expandable","disabledItems","elementToItem","itemToElement","pressedClassName","ripples","handlers","event","isLink","ContentComponent","isMediaLeftAddon","li","role","expander","aria-expanded","aria-selected","aria-disabled","ref","tabIndex","link","isLeft","addon","temporary","collapsed"],"mappings":"AAAA;;AACA,SACEA,SAAS,QAKJ,QAAQ;AACf,SAASC,qBAAqB,QAAQ,0CAA0C;AAChF,SAASC,yBAAyB,QAAQ,8CAA8C;AACxF,SAASC,gBAAgB,QAAQ,8BAA8B;AAC/D,SAASC,0BAA0B,QAAQ,6CAA6C;AAExF,SAASC,YAAY,QAAQ,qBAAqB;AAClD,SAASC,SAAS,QAAwC,iBAAiB;AAC3E,SAASC,gBAAgB,QAAQ,wBAAwB;AACzD,SAASC,cAAc,QAAQ,oBAAoB;AACnD,SAASC,QAAQ,EAAEC,eAAe,EAAEC,aAAa,QAAQ,cAAc;AA6DvE;;;;;;;;;;CAUC,GACD,OAAO,SAASC,SAASC,KAAoB;IAC3C,MAAM,EACJC,IAAIC,MAAM,EACVC,KAAK,EACLC,OAAO,EACPC,WAAW,KAAK,EAChBC,kBAAkB,KAAK,EACvBC,UAAU,EACVC,UAAUC,YAAY,EACtBC,SAAS,EACTC,MAAM,EACNC,SAAS,EACTC,eAAeC,iBAAiB,EAChCC,iBAAiB,EACjBC,kBAAkB,EAClBC,kBAAkB,EAClBC,UAAU,EACVC,cAAc,EACdC,kBAAkB,EAClBC,mBAAmB,EACnBC,mBAAmB,EACnBC,mBAAmB,EACnBC,+BAA+BC,iCAAiC,EAChEC,8BAA8B,EAC9BC,SAAS,EACTC,aAAa,EACbC,WAAW,EACXC,aAAa,EACbC,kBAAkB,EAClBC,sBAAsB,EACtBC,SAAS,EACTC,UAAU,EACVC,gBAAgB,EAChBC,mBAAmB,EACnBC,mBAAmBC,qBAAqB,EACxCC,MAAM,EACNC,OAAO,EACPC,SAAS,EACTC,OAAO,EACPC,WAAW,EACXC,SAAS,EACTC,YAAY,EACZC,WAAW,EACXC,YAAY,EACZC,UAAU,EACVC,WAAW,EACXC,UAAU,EACV,GAAGC,WACJ,GAAGnD;IAEJ,MAAMC,KAAKT,aAAaU,QAAQ;IAChC,MAAMM,WAAWnB,0BAA0BoB;IAC3C,IAAIJ,UAAU;QACZ,mEAAmE;QACnE,oBAAoB;QACpB8C,UAAUC,EAAE,GAAGC;QACfF,UAAUG,IAAI,GAAGD;IACnB;IAEA,MAAM,EACJE,WAAW,EACXC,WAAW,EACXC,YAAY,EACZC,aAAa,EACbC,cAAc,EACdC,eAAeC,IAAI,EACnBC,uBAAuB,EACvBC,uBAAuB,EACvB1B,mBAAmB2B,wBAAwB,EAC5C,GAAGrE;IACJ,MAAM,EAAEsE,kBAAkB,EAAE,GAAG1E;IAE/B,MAAM2E,aAAa,CAAChC;IACpB,MAAMiC,UAAUF,uBAAuBhE;IACvC,MAAMmE,WAAWb,YAAYc,GAAG,CAAC1D;IACjC,MAAM2D,WAAWd,YAAYa,GAAG,CAAC1D;IACjC,MAAM0B,oBAAoBC,yBAAyB0B;IAEnD7E,UAAU;QACR,MAAMoF,SAASZ,eAAea,OAAO;QACrCD,OAAOE,UAAU,CAAC9D,OAAO,GAAG,CAACuD;QAC7BK,OAAOG,aAAa,CAAC/D,OAAO,GAAGN;QAC/BkE,OAAOI,aAAa,CAAC1E,GAAG,GAAGU;QAC3B4D,OAAOK,aAAa,CAACjE,OAAO,GAAGV;QAE/B,OAAO;YACL,OAAOsE,OAAOG,aAAa,CAAC/D,OAAO;YACnC,OAAO4D,OAAOE,UAAU,CAAC9D,OAAO;YAChC,OAAO4D,OAAOI,aAAa,CAAC1E,GAAG;YAC/B,OAAOsE,OAAOK,aAAa,CAACjE,OAAO;QACrC;IACF,GAAG;QAACV;QAAI0D;QAAgBhD;QAAQuD;QAAY7D;QAAUF;KAAM;IAE5D,MAAM,EAAE0E,gBAAgB,EAAEC,OAAO,EAAEC,QAAQ,EAAE,GAC3C3F,sBAAqC;QACnCmD;QACAC,SAAQwC,KAAK;YACXxC,UAAUwC;YACVlB,wBAAwBnD;YACxB,IAAI,CAACuD,cAAcR,kBAAkB,UAAU;gBAC7CK,wBAAwBpD;YAC1B;QACF;QACA8B;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACA5C;IACF;IAEF,MAAM4E,SAAS,CAAC,CAAE9B,CAAAA,UAAUC,EAAE,IAAID,UAAUG,IAAI,AAAD;IAE/C,oEAAoE;IACpE,MAAM4B,mBAAoBD,SAASpB,OAAO;IAC1C,MAAMhD,gBACJC,qBAAsB2C,CAAAA,gBAAgB7C,SAAQ,IAAK,UAAUyC;IAC/D,MAAM8B,mBACJ,OAAOrE,sBAAsB,eAAeD,kBAAkB;IAChE,MAAMW,gCACJC,qCAAqC0D;IAEvC,qBACE,MAACC;QACE,GAAGhF,OAAO;QACXiF,MAAK;QACL3E,WAAWd,SAAS;YAClBc;YACA4E,UAAU,CAAC,CAACpD;YACZuB;QACF;;0BAEA,MAACyB;gBACE,GAAG/B,SAAS;gBACb,sEAAsE;gBACtE,+DAA+D;gBAC/DoC,iBAAerB,aAAab,YAAYe;gBACxCoB,iBAAelB;gBACfmB,iBAAepF,YAAYgD;gBAC3BpD,IAAIA;gBACJyF,KAAKxC;gBACLmC,MAAK;gBACLM,UAAU,CAAC;gBACV,GAAGZ,QAAQ;gBACZrE,WAAWb,gBAAgB;oBACzB+F,MAAMX;oBACNd;oBACAG;oBACAjE;oBACAC;oBACAI,WAAWyB;oBACX0C;gBACF;;kCAEA,KAACvF;wBACC2C,WAAWA;wBACXL,eAAeA;wBACfI,wBAAwBA;wBACxBT,qBAAqBA;wBACrBM,aAAaA;wBACbF,WAAWA;wBACXG,eAAeA;wBACfC,oBAAoBA;wBACpBnB,yBACE,KAAClB;4BACCmG,MAAM;4BACNlF,QAAQA;4BACRmF,OAAOlF;4BACPwD,UAAUA;4BACV/D,UAAUA;4BACV6D,YAAYA;;wBAGhBrD,eAAeA;wBACfE,mBAAmBA;wBACnBC,oBAAoBlB,cAAc;4BAChCoE;4BACAiB;4BACAzE,WAAWM;wBACb;wBACAC,oBAAoBA;wBACpBC,0BACE,KAACxB;4BACCiB,QAAQA;4BACRmF,OAAO5E;4BACPkD,UAAUA;4BACV/D,UAAUA;4BACV6D,YAAYA;;wBAGhB/C,gBAAgBA;wBAChBC,oBAAoBA;wBACpBC,qBAAqBA;wBACrBC,qBAAqBA;wBACrBE,+BAA+BA;wBAC/BE,gCAAgCA;kCAE/BlB;;oBAEFsE;;;0BAEH,KAACrF;gBACCQ,IAAI,CAAC,EAAEA,GAAG,MAAM,CAAC;gBACjB8F,WAAW3D;gBACXC,mBAAmBA;gBAClB,GAAG9B,UAAU;gBACdJ,OAAOA,QAAQ;gBACf6F,WAAW9B,cAAc,CAACE;0BAEzBlC;;;;AAIT"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/TreeItemExpander.tsx"],"sourcesContent":["\"use client\";\nimport { cnb } from \"cnbuilder\";\nimport {\n cloneElement,\n isValidElement,\n type MouseEventHandler,\n type ReactElement,\n type ReactNode,\n} from \"react\";\nimport { getIcon } from \"../icon/iconConfig.js\";\nimport { IconRotator } from \"../icon/IconRotator.js\";\nimport { useTreeContext } from \"./TreeProvider.js\";\n\n/**\n * @internal\n * @remarks \\@since 6.0.0 Updated to use the latest API\n */\nexport interface TreeItemExpanderProps {\n /** @defaultValue `false` */\n isLeft?: boolean;\n itemId: string;\n addon: ReactNode;\n disabled: boolean;\n expanded: boolean;\n isLeafNode: boolean;\n className?: string;\n}\n\n/**\n * **Client Component**\n *\n * @internal\n * @remarks \\@since 6.0.0 Updated to support the new `expansionMode` behavior.\n */\nexport function TreeItemExpander(props: TreeItemExpanderProps): ReactElement {\n const {\n itemId,\n isLeft = false,\n addon,\n expanded,\n disabled,\n isLeafNode,\n className,\n } = props;\n const {\n expanderIcon,\n expanderLeft,\n expansionMode,\n disableTransition,\n toggleTreeItemExpansion,\n } = useTreeContext();\n\n const icon = getIcon(\"dropdown\", expanderIcon);\n if (isLeafNode || expanderLeft !== isLeft) {\n if (isValidElement<{ className?: string }>(addon)) {\n return cloneElement(addon, { className });\n }\n\n return <>{addon}</>;\n }\n\n const isCloneable = isValidElement(icon);\n let clickProps: { onClick: MouseEventHandler<Element> } | undefined;\n if (expansionMode === \"manual\" && !disabled) {\n clickProps = {\n onClick(event) {\n // do not select the tree item if the icon is clicked\n event.stopPropagation();\n event.preventDefault();\n\n toggleTreeItemExpansion(itemId);\n },\n };\n }\n\n return (\n <>\n <IconRotator\n className={cnb(!addon && className)}\n {...(!isCloneable ? clickProps : undefined)}\n rotated={expanded}\n forceIconWrap={!isCloneable}\n disableTransition={disableTransition}\n >\n {clickProps && isCloneable ? cloneElement(icon, clickProps) : icon}\n </IconRotator>\n {addon}\n </>\n );\n}\n"],"names":["cnb","cloneElement","isValidElement","getIcon","IconRotator","useTreeContext","TreeItemExpander","props","itemId","isLeft","addon","expanded","disabled","isLeafNode","className","expanderIcon","expanderLeft","expansionMode","disableTransition","toggleTreeItemExpansion","icon","isCloneable","clickProps","onClick","event","stopPropagation","preventDefault","undefined","rotated","forceIconWrap"],"mappings":"AAAA;;AACA,SAASA,GAAG,QAAQ,YAAY;AAChC,SACEC,YAAY,EACZC,cAAc,QAIT,QAAQ;AACf,SAASC,OAAO,QAAQ,wBAAwB;AAChD,SAASC,WAAW,QAAQ,yBAAyB;AACrD,SAASC,cAAc,QAAQ,oBAAoB;AAiBnD;;;;;CAKC,GACD,OAAO,SAASC,iBAAiBC,KAA4B;IAC3D,MAAM,EACJC,MAAM,EACNC,SAAS,KAAK,EACdC,KAAK,EACLC,QAAQ,EACRC,QAAQ,EACRC,UAAU,EACVC,SAAS,EACV,GAAGP;IACJ,MAAM,EACJQ,YAAY,EACZC,YAAY,EACZC,aAAa,EACbC,iBAAiB,EACjBC,uBAAuB,EACxB,GAAGd;IAEJ,MAAMe,OAAOjB,QAAQ,YAAYY;IACjC,IAAIF,cAAcG,iBAAiBP,QAAQ;QACzC,kBAAIP,eAAuCQ,QAAQ;YACjD,qBAAOT,aAAaS,OAAO;gBAAEI;YAAU;QACzC;QAEA,qBAAO;sBAAGJ;;IACZ;IAEA,MAAMW,4BAAcnB,eAAekB;IACnC,IAAIE;IACJ,IAAIL,kBAAkB,YAAY,CAACL,UAAU;QAC3CU,aAAa;YACXC,SAAQC,KAAK;gBACX,qDAAqD;gBACrDA,MAAMC,eAAe;gBACrBD,MAAME,cAAc;gBAEpBP,wBAAwBX;YAC1B;QACF;IACF;IAEA,qBACE;;0BACE,KAACJ;gBACCU,WAAWd,IAAI,CAACU,SAASI;gBACxB,GAAI,CAACO,cAAcC,aAAaK,SAAS;gBAC1CC,SAASjB;gBACTkB,eAAe,CAACR;gBAChBH,mBAAmBA;0BAElBI,cAAcD,4BAAcpB,aAAamB,MAAME,cAAcF;;YAE/DV;;;AAGP"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/TreeProvider.tsx"],"sourcesContent":["\"use client\";\nimport {\n createContext,\n useContext,\n useMemo,\n type ReactElement,\n type ReactNode,\n} from \"react\";\nimport { type CustomLinkComponent } from \"../link/Link.js\";\nimport { type NonNullRef } from \"../types.js\";\nimport {\n type DefaultTreeItemNode,\n type TreeData,\n type TreeItemNode,\n} from \"./types.js\";\nimport { type TreeExpansion } from \"./useTreeExpansion.js\";\nimport { type TreeSelection } from \"./useTreeSelection.js\";\n\n/**\n * When this is set to `\"auto\"`, clicking on a tree item with a mouse or with\n * the Enter/Space keys will select and expand/collapse the tree item. The user\n * can still use the ArrowLeft and ArrowRight keys to expand/collapse nested\n * tree items.\n *\n * When this is set to `\"manual\"`, clicking on a tree item with a mouse or with\n * the Enter/Space keys will only select that tree item. The user must use the\n * ArrowLeft and ArrowRight keys to expand/collapse nested tree items.\n *\n * The main use-case for the `\"manual\"` setting is creating a navigation tree\n * that requires the user to click on an icon or a button to expand the child\n * items.\n *\n * @remarks \\@since 6.0.0\n */\nexport type TreeExpansionMode = \"auto\" | \"manual\";\n\n/**\n * @internal\n * @remarks \\@since 6.0.0\n */\nexport interface TreeItemMetadataLookup {\n /**\n * This is used for the keyboard movement behavior for trees that allow the\n * `ArrowRight` key for tree items that have children.\n */\n expandable: Record<string, boolean>;\n\n /**\n * This is a quick lookup if a tree item is disabled since it's possible the\n * custom `renderer` sets the `disabled` state and not the `TreeData`.\n */\n disabledItems: Record<string, boolean>;\n\n /**\n * A lookup of element `id` (DOM id) for each tree item to the `itemId`. This\n * is a quick way to figure out which item is being interacted with from a\n * keyboard event without needed to add `data-*` attributes.\n */\n elementToItem: Record<string, string>;\n\n /**\n * A lookup of tree item `itemId` to the element `id` (DOM id). This is used\n * to be able to find a parent tree item when the `ArrowLeft` key is pressed\n * to focus that parent item.\n */\n itemToElement: Record<string, string>;\n}\n\n/**\n * The tree context is mostly a convenience API for implementing a custom tree\n * item that requires the {@link TreeExpansion}, {@link TreeSelection} and\n * {@link TreeData} to work.\n *\n * The other properties on the context are most likely for internal use only.\n *\n * @remarks \\@since 6.0.0\n */\nexport interface TreeContext<T extends TreeItemNode = DefaultTreeItemNode>\n extends TreeExpansion,\n TreeSelection {\n data: TreeData<T>;\n rootId: string | null;\n disableTransition: boolean;\n temporaryChildItems: boolean;\n\n linkComponent: CustomLinkComponent;\n\n /** @internal */\n expanderLeft: boolean;\n /** @internal */\n expanderIcon: ReactNode;\n /** @internal */\n expansionMode: TreeExpansionMode;\n /** @internal */\n metadataLookup: NonNullRef<TreeItemMetadataLookup>;\n}\n\n// Allow the hook to correct typecast this instead\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst context = createContext<TreeContext<any> | undefined>(undefined);\ncontext.displayName = \"Tree\";\nconst { Provider } = context;\n\n/**\n * This can be used for a custom tree item renderer.\n *\n * @see The `Tree` component for an example.\n * @remarks \\@since 6.0.0\n */\nexport function useTreeContext<\n T extends TreeItemNode = DefaultTreeItemNode,\n>(): TreeContext<T> {\n const value = useContext(context);\n if (!value) {\n throw new Error(\"Cannot find a parent Tree component\");\n }\n\n return value;\n}\n\n/**\n * @internal\n * @remarks \\@since 6.0.0\n */\nexport interface TreeProviderProps<T extends TreeItemNode = DefaultTreeItemNode>\n extends TreeContext<T> {\n children: ReactNode;\n}\n\n/**\n * **Client Component**\n *\n * @internal\n * @remarks \\@since 6.0.0\n */\nexport function TreeProvider<T extends TreeItemNode = DefaultTreeItemNode>(\n props: TreeProviderProps<T>\n): ReactElement {\n const {\n children,\n data,\n rootId,\n multiSelect,\n expanderIcon,\n expanderLeft,\n expansionMode,\n metadataLookup,\n disableTransition,\n temporaryChildItems,\n linkComponent,\n expandedIds,\n selectedIds,\n expandMultipleTreeItems,\n toggleTreeItemExpansion,\n selectMultipleTreeItems,\n toggleTreeItemSelection,\n } = props;\n const value = useMemo<TreeContext<T>>(\n () => ({\n data,\n rootId,\n multiSelect,\n expanderIcon,\n expanderLeft,\n expansionMode,\n metadataLookup,\n disableTransition,\n temporaryChildItems,\n linkComponent,\n expandedIds,\n selectedIds,\n expandMultipleTreeItems,\n toggleTreeItemExpansion,\n selectMultipleTreeItems,\n toggleTreeItemSelection,\n }),\n [\n data,\n disableTransition,\n expandMultipleTreeItems,\n expandedIds,\n expanderIcon,\n expanderLeft,\n expansionMode,\n linkComponent,\n metadataLookup,\n multiSelect,\n rootId,\n selectMultipleTreeItems,\n selectedIds,\n temporaryChildItems,\n toggleTreeItemExpansion,\n toggleTreeItemSelection,\n ]\n );\n\n return <Provider value={value}>{children}</Provider>;\n}\n"],"names":["createContext","useContext","useMemo","context","undefined","displayName","Provider","useTreeContext","value","Error","TreeProvider","props","children","data","rootId","multiSelect","expanderIcon","expanderLeft","expansionMode","metadataLookup","disableTransition","temporaryChildItems","linkComponent","expandedIds","selectedIds","expandMultipleTreeItems","toggleTreeItemExpansion","selectMultipleTreeItems","toggleTreeItemSelection"],"mappings":"AAAA;;AACA,SACEA,aAAa,EACbC,UAAU,EACVC,OAAO,QAGF,QAAQ;AA0Ff,kDAAkD;AAClD,8DAA8D;AAC9D,MAAMC,wBAAUH,cAA4CI;AAC5DD,QAAQE,WAAW,GAAG;AACtB,MAAM,EAAEC,QAAQ,EAAE,GAAGH;AAErB;;;;;CAKC,GACD,OAAO,SAASI;IAGd,MAAMC,QAAQP,WAAWE;IACzB,IAAI,CAACK,OAAO;QACV,MAAM,IAAIC,MAAM;IAClB;IAEA,OAAOD;AACT;AAWA;;;;;CAKC,GACD,OAAO,SAASE,aACdC,KAA2B;IAE3B,MAAM,EACJC,QAAQ,EACRC,IAAI,EACJC,MAAM,EACNC,WAAW,EACXC,YAAY,EACZC,YAAY,EACZC,aAAa,EACbC,cAAc,EACdC,iBAAiB,EACjBC,mBAAmB,EACnBC,aAAa,EACbC,WAAW,EACXC,WAAW,EACXC,uBAAuB,EACvBC,uBAAuB,EACvBC,uBAAuB,EACvBC,uBAAuB,EACxB,GAAGjB;IACJ,MAAMH,QAAQN,QACZ,IAAO,CAAA;YACLW;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;QACF,CAAA,GACA;QACEf;QACAO;QACAK;QACAF;QACAP;QACAC;QACAC;QACAI;QACAH;QACAJ;QACAD;QACAa;QACAH;QACAH;QACAK;QACAE;KACD;IAGH,qBAAO,KAACtB;QAASE,OAAOA;kBAAQI;;AAClC"}
@@ -0,0 +1,58 @@
1
+ import { cnb } from "cnbuilder";
2
+ import { listItem } from "../list/listItemStyles.js";
3
+ import { bem } from "../utils/bem.js";
4
+ const treeStyles = bem("rmd-tree");
5
+ const treeItemStyles = bem("rmd-tree-item");
6
+ const treeGroupStyles = bem("rmd-tree-group");
7
+ /**
8
+ * Apply the `className`s for a tree component. This will be type-safe if using
9
+ * typescript.
10
+ *
11
+ * @remarks \@since 6.0.0
12
+ */ export function tree(options = {}) {
13
+ const { className } = options;
14
+ return cnb(treeStyles(), className);
15
+ }
16
+ /**
17
+ * Apply the `className`s for a tree item component. This will be type-safe if
18
+ * using typescript.
19
+ *
20
+ * @remarks \@since 6.0.0
21
+ */ export function treeItem(options = {}) {
22
+ const { className, expander = false, expanderLeft = false } = options;
23
+ return cnb(treeItemStyles({
24
+ "expander-left": expander && expanderLeft,
25
+ "expander-right": expander && !expanderLeft
26
+ }), className);
27
+ }
28
+ /**
29
+ * @remarks \@since 6.0.0
30
+ */ export function treeItemContent(options = {}) {
31
+ const { className, link = false, focused, selected, disabled = false, ...remaining } = options;
32
+ return cnb(treeItemStyles("content", {
33
+ link,
34
+ focused,
35
+ selected,
36
+ disabled
37
+ }), listItem({
38
+ className,
39
+ disabled,
40
+ ...remaining
41
+ }));
42
+ }
43
+ /**
44
+ * @remarks \@since 6.0.0
45
+ */ export function treeItemMedia(options) {
46
+ const { isLeafNode, isMediaLeftAddon, className } = options;
47
+ return cnb(isMediaLeftAddon && treeItemStyles("media", {
48
+ single: isLeafNode
49
+ }), className);
50
+ }
51
+ /**
52
+ * @remarks \@since 6.0.0
53
+ */ export function treeGroup(options = {}) {
54
+ const { className } = options;
55
+ return cnb(treeGroupStyles(), className);
56
+ }
57
+
58
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/styles.ts"],"sourcesContent":["import { cnb } from \"cnbuilder\";\nimport type { InternalListItemClassNameOptions } from \"../list/listItemStyles.js\";\nimport { listItem } from \"../list/listItemStyles.js\";\nimport { bem } from \"../utils/bem.js\";\n\nconst treeStyles = bem(\"rmd-tree\");\nconst treeItemStyles = bem(\"rmd-tree-item\");\nconst treeGroupStyles = bem(\"rmd-tree-group\");\n\n/** @remarks \\@since 6.0.0 */\nexport interface TreeClassNameOptions {\n className?: string;\n}\n\n/**\n * Apply the `className`s for a tree component. This will be type-safe if using\n * typescript.\n *\n * @remarks \\@since 6.0.0\n */\nexport function tree(options: TreeClassNameOptions = {}): string {\n const { className } = options;\n\n return cnb(treeStyles(), className);\n}\n\n/** @remarks \\@since 6.0.0 */\nexport interface TreeItemClassNameOptions {\n className?: string;\n expander?: boolean;\n\n /**\n * Settings this to `true` will update the styles for the expander icon within\n * the tree item to rotate `down -> right` instead of `down -> left`.\n *\n * @defaultValue `false`\n */\n expanderLeft?: boolean;\n}\n\n/**\n * Apply the `className`s for a tree item component. This will be type-safe if\n * using typescript.\n *\n * @remarks \\@since 6.0.0\n */\nexport function treeItem(options: TreeItemClassNameOptions = {}): string {\n const { className, expander = false, expanderLeft = false } = options;\n\n return cnb(\n treeItemStyles({\n \"expander-left\": expander && expanderLeft,\n \"expander-right\": expander && !expanderLeft,\n }),\n className\n );\n}\n\n/** @remarks \\@since 6.0.0 */\nexport interface TreeItemContentClassNameOptions\n extends InternalListItemClassNameOptions {\n /**\n * Set this\n *\n * @defaultValue `false`\n */\n link?: boolean;\n\n /**\n * Set this to `true` when the tree item is the current keyboard focus with\n * `aria-activedescendant`. This will apply the focus styles only while the\n * parent tree component is focused and the user is in keyboard mode.\n *\n *\n * @defaultValue `false`\n */\n focused?: boolean;\n\n /**\n * Set this to `true` hen the tree item has been selected by the user. The\n * default styles just\n *\n * @defaultValue `false`\n */\n selected?: boolean;\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport function treeItemContent(\n options: TreeItemContentClassNameOptions = {}\n): string {\n const {\n className,\n link = false,\n focused,\n selected,\n disabled = false,\n ...remaining\n } = options;\n\n return cnb(\n treeItemStyles(\"content\", {\n link,\n focused,\n selected,\n disabled,\n }),\n listItem({\n className,\n disabled,\n ...remaining,\n })\n );\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface TreeItemMediaClassNameOptions {\n className?: string;\n isLeafNode: boolean;\n isMediaLeftAddon: boolean;\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport function treeItemMedia(options: TreeItemMediaClassNameOptions): string {\n const { isLeafNode, isMediaLeftAddon, className } = options;\n\n return cnb(\n isMediaLeftAddon && treeItemStyles(\"media\", { single: isLeafNode }),\n className\n );\n}\n\n/** @remarks \\@since 6.0.0 */\nexport interface TreeGroupClassNameOptions {\n className?: string;\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport function treeGroup(options: TreeGroupClassNameOptions = {}): string {\n const { className } = options;\n\n return cnb(treeGroupStyles(), className);\n}\n"],"names":["cnb","listItem","bem","treeStyles","treeItemStyles","treeGroupStyles","tree","options","className","treeItem","expander","expanderLeft","treeItemContent","link","focused","selected","disabled","remaining","treeItemMedia","isLeafNode","isMediaLeftAddon","single","treeGroup"],"mappings":"AAAA,SAASA,GAAG,QAAQ,YAAY;AAEhC,SAASC,QAAQ,QAAQ,4BAA4B;AACrD,SAASC,GAAG,QAAQ,kBAAkB;AAEtC,MAAMC,aAAaD,IAAI;AACvB,MAAME,iBAAiBF,IAAI;AAC3B,MAAMG,kBAAkBH,IAAI;AAO5B;;;;;CAKC,GACD,OAAO,SAASI,KAAKC,UAAgC,CAAC,CAAC;IACrD,MAAM,EAAEC,SAAS,EAAE,GAAGD;IAEtB,OAAOP,IAAIG,cAAcK;AAC3B;AAgBA;;;;;CAKC,GACD,OAAO,SAASC,SAASF,UAAoC,CAAC,CAAC;IAC7D,MAAM,EAAEC,SAAS,EAAEE,WAAW,KAAK,EAAEC,eAAe,KAAK,EAAE,GAAGJ;IAE9D,OAAOP,IACLI,eAAe;QACb,iBAAiBM,YAAYC;QAC7B,kBAAkBD,YAAY,CAACC;IACjC,IACAH;AAEJ;AA+BA;;CAEC,GACD,OAAO,SAASI,gBACdL,UAA2C,CAAC,CAAC;IAE7C,MAAM,EACJC,SAAS,EACTK,OAAO,KAAK,EACZC,OAAO,EACPC,QAAQ,EACRC,WAAW,KAAK,EAChB,GAAGC,WACJ,GAAGV;IAEJ,OAAOP,IACLI,eAAe,WAAW;QACxBS;QACAC;QACAC;QACAC;IACF,IACAf,SAAS;QACPO;QACAQ;QACA,GAAGC,SAAS;IACd;AAEJ;AAWA;;CAEC,GACD,OAAO,SAASC,cAAcX,OAAsC;IAClE,MAAM,EAAEY,UAAU,EAAEC,gBAAgB,EAAEZ,SAAS,EAAE,GAAGD;IAEpD,OAAOP,IACLoB,oBAAoBhB,eAAe,SAAS;QAAEiB,QAAQF;IAAW,IACjEX;AAEJ;AAOA;;CAEC,GACD,OAAO,SAASc,UAAUf,UAAqC,CAAC,CAAC;IAC/D,MAAM,EAAEC,SAAS,EAAE,GAAGD;IAEtB,OAAOP,IAAIK,mBAAmBG;AAChC"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/types.ts"],"sourcesContent":["import type { ReactNode } from \"react\";\nimport type { ListItemChildrenProps } from \"../list/types.js\";\nimport type { UseStateInitializer } from \"../types.js\";\n\n/**\n * @remarks \\@since 6.0.0 This was renamed from `TreeItemIds`\n */\nexport interface TreeItemNode {\n itemId: string;\n parentId: string | null;\n}\n\n/**\n * The default tree item node allows for any props for rendering children within\n * list items and rendering links.\n *\n * @remarks \\@since 6.0.0\n */\nexport interface DefaultTreeItemNode\n extends TreeItemNode,\n ListItemChildrenProps {\n /**\n * If this is defined, the `TreeItem` will render the content within a `Link`\n * instead of a `<span>`.\n */\n to?: string;\n\n /**\n * If this is defined, the `TreeItem` will render the content within a `Link`\n * instead of a `<span>`.\n */\n href?: string;\n\n /**\n * This should only be provided if {@link to} or {@link href} exist on the\n * node.\n */\n rel?: string;\n\n /**\n * This should only be provided if {@link to} or {@link href} exist on the\n * node.\n */\n target?: string;\n\n /**\n * An alias for the {@link children} within a tree item. This will be used\n * over the {@link children} if both exist.\n */\n name?: ReactNode;\n\n /**\n * The children to display in the tree item.\n *\n * @see {@link name}\n */\n children?: ReactNode;\n\n /** @see {@link ListItemProps.disabled} */\n disabled?: boolean;\n\n /** @see {@link ListItemProps.disabledOpacity} */\n disabledOpacity?: boolean;\n\n className?: string;\n contentClassName?: string;\n}\n\n/**\n * @example\n * Default Structure\n * ```tsx\n * import type { TreeData } from \"@react-md/core\";\n * import FolderIcon from \"@react-md/material-icons/FolderIcon\";\n *\n * export const MY_DATA: TreeData = {\n * \"item-1\": {\n * itemId: \"item-1\",\n * parentId: null,\n * name: \"Root Level Item 1\",\n * },\n * \"item-2\": {\n * itemId: \"item-2\",\n * parentId: \"item-1\",\n * name: \"A child for the first item\",\n * leftAddon: <FolderIcon />,\n * },\n * \"item-3\": {\n * itemId: \"item-3\",\n * parentId: \"item-1\",\n * children: \"Another child for the first item\",\n * leftAddon: <FolderIcon />,\n * rightAddon: <span>Something custom</span>,\n * },\n * };\n * ```\n *\n * @remarks \\@since 6.0.0 Updated the default types\n * @see {@link DefaultTreeItemNode}\n */\nexport type TreeData<T extends TreeItemNode = DefaultTreeItemNode> = Record<\n string,\n T\n>;\n\n/**\n * @remarks \\@since 6.0.0 This used to be `TreeItemIds` but was converted to a\n * Set to increase performance for large trees.\n */\nexport type TreeItemIdSet = ReadonlySet<string>;\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport type TreeItemDefaultIds = UseStateInitializer<readonly string[]>;\n\n/**\n * A function to call that will sort the items within the tree for each unique\n * `parentId`. If you have a tree like:\n *\n * ```\n * a\n * ├── a1\n * b\n * ├── b1\n * ├── b2\n * │ └── b2.1\n * c\n * ├── c1\n * ├── c2\n * └── c3\n * ```\n *\n * This function will be called with:\n *\n * - `[a1]`\n * - `[b2.1]`\n * - `[b1, b2]`\n * - `[c1, c2, c3]`\n * - `[a, b, c]`\n *\n * Note: This **should be memoized** to prevent rerendering the entire tree each\n * render.\n */\nexport type TreeItemSorter<T extends TreeItemNode = DefaultTreeItemNode> = (\n items: readonly T[]\n) => readonly T[];\n"],"names":[],"mappings":"AAoHA;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2BC,GACD,WAEkB"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/useTree.ts"],"sourcesContent":["\"use client\";\nimport type { TreeItemDefaultIds } from \"./types.js\";\nimport type { TreeExpansion } from \"./useTreeExpansion.js\";\nimport { useTreeExpansion } from \"./useTreeExpansion.js\";\nimport type { TreeSelection } from \"./useTreeSelection.js\";\nimport { useTreeSelection } from \"./useTreeSelection.js\";\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface TreeHookOptions {\n /**\n * @defaultValue `false`\n */\n multiSelect?: boolean;\n\n /**\n * @defaultValue `[]`\n */\n defaultExpandedIds?: TreeItemDefaultIds;\n\n /**\n * @defaultValue `[]`\n */\n defaultSelectedIds?: TreeItemDefaultIds;\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface TreeImplementation extends TreeSelection, TreeExpansion {}\n\n/**\n * This is a convenience wrapper for the {@link useTreeExpansion} and\n * {@link useTreeSelection} hooks since they will almost always be used together.\n *\n * @example\n * Simple Example\n * ```tsx\n * import type { TreeData } from \"@react-md/core\";\n * import { Tree, useTree } from \"@react-md/core\";\n * import type { ReactElement } from \"react\";\n *\n * const data: TreeData = {\n * // pretend data\n * };\n *\n * function Example(): ReactElement {\n * const tree = useTree();\n *\n * return <Tree {...tree} data={data} aria-label=\"Tree\" />;\n * }\n * ```\n *\n * @remarks \\@since 6.0.0\n */\nexport function useTree(options: TreeHookOptions = {}): TreeImplementation {\n const {\n multiSelect = false,\n defaultExpandedIds,\n defaultSelectedIds,\n } = options;\n\n return {\n ...useTreeExpansion(defaultExpandedIds),\n ...useTreeSelection(defaultSelectedIds, multiSelect),\n };\n}\n"],"names":["useTreeExpansion","useTreeSelection","useTree","options","multiSelect","defaultExpandedIds","defaultSelectedIds"],"mappings":"AAAA;AAGA,SAASA,gBAAgB,QAAQ,wBAAwB;AAEzD,SAASC,gBAAgB,QAAQ,wBAAwB;AA2BzD;;;;;;;;;;;;;;;;;;;;;;;CAuBC,GACD,OAAO,SAASC,QAAQC,UAA2B,CAAC,CAAC;IACnD,MAAM,EACJC,cAAc,KAAK,EACnBC,kBAAkB,EAClBC,kBAAkB,EACnB,GAAGH;IAEJ,OAAO;QACL,GAAGH,iBAAiBK,mBAAmB;QACvC,GAAGJ,iBAAiBK,oBAAoBF,YAAY;IACtD;AACF"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/useTreeExpansion.ts"],"sourcesContent":["\"use client\";\nimport { useCallback, useState } from \"react\";\nimport type { UseStateSetter } from \"../types.js\";\nimport type { TreeItemDefaultIds, TreeItemIdSet } from \"./types.js\";\n\n/**\n * @remarks \\@since 6.0.0 Renamed from `TreeItemExpansion` and uses a Set\n * instead of a list to increase performance. Also renamed `onItemExpansion` to\n * `toggleTreeItemExpansion` and `onMultiItemExpansion` to\n * `expandMultipleTreeItems`.\n */\nexport interface TreeExpansion {\n expandedIds: TreeItemIdSet;\n toggleTreeItemExpansion(itemId: string): void;\n expandMultipleTreeItems: UseStateSetter<TreeItemIdSet>;\n}\n\n/**\n * @remarks \\@since 6.0.0 Renamed from `useTreeItemExpansion` and uses a Set\n * instead of a list to increase performance.\n */\nexport function useTreeExpansion(\n defaultExpandedIds?: TreeItemDefaultIds\n): TreeExpansion {\n const [expandedIds, setExpandedIds] = useState<TreeItemIdSet>(() => {\n const defaultIds =\n typeof defaultExpandedIds === \"function\"\n ? defaultExpandedIds()\n : defaultExpandedIds;\n\n return new Set(defaultIds);\n });\n\n const toggleTreeItemExpansion = useCallback((itemId: string) => {\n setExpandedIds((prevExpandedIds) => {\n const expandedIds = new Set(prevExpandedIds);\n if (expandedIds.has(itemId)) {\n expandedIds.delete(itemId);\n } else {\n expandedIds.add(itemId);\n }\n\n return expandedIds;\n });\n }, []);\n\n return {\n expandedIds,\n toggleTreeItemExpansion,\n expandMultipleTreeItems: setExpandedIds,\n };\n}\n"],"names":["useCallback","useState","useTreeExpansion","defaultExpandedIds","expandedIds","setExpandedIds","defaultIds","Set","toggleTreeItemExpansion","itemId","prevExpandedIds","has","delete","add","expandMultipleTreeItems"],"mappings":"AAAA;AACA,SAASA,WAAW,EAAEC,QAAQ,QAAQ,QAAQ;AAgB9C;;;CAGC,GACD,OAAO,SAASC,iBACdC,kBAAuC;IAEvC,MAAM,CAACC,aAAaC,eAAe,GAAGJ,SAAwB;QAC5D,MAAMK,aACJ,OAAOH,uBAAuB,aAC1BA,uBACAA;QAEN,OAAO,IAAII,IAAID;IACjB;IAEA,MAAME,0BAA0BR,YAAY,CAACS;QAC3CJ,eAAe,CAACK;YACd,MAAMN,cAAc,IAAIG,IAAIG;YAC5B,IAAIN,YAAYO,GAAG,CAACF,SAAS;gBAC3BL,YAAYQ,MAAM,CAACH;YACrB,OAAO;gBACLL,YAAYS,GAAG,CAACJ;YAClB;YAEA,OAAOL;QACT;IACF,GAAG,EAAE;IAEL,OAAO;QACLA;QACAI;QACAM,yBAAyBT;IAC3B;AACF"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/useTreeItems.ts"],"sourcesContent":["import { useMemo } from \"react\";\nimport type {\n TreeItemSorter,\n TreeItemNode,\n TreeData,\n DefaultTreeItemNode,\n} from \"./types.js\";\n\n/**\n * A lookup to find all the child ids for a specific parent. This was added to\n * support the `*` keyboard behavior of opening all tree items at the current\n * level.\n *\n * @remarks \\@since 6.0.0\n * @internal\n */\nexport type TreeItemChildIds = Map<string | null, Set<string>>;\n\n/**\n * @remarks \\@since 6.0.0\n * @internal\n */\nexport type RenderableTreeItemNode<\n T extends TreeItemNode = DefaultTreeItemNode,\n> = T & {\n items?: readonly RenderableTreeItemNode<T>[];\n};\n\n/**\n * @remarks \\@since 6.0.0\n * @internal\n */\nexport interface BuildTreeOptions<T extends TreeItemNode> {\n sort: TreeItemSorter<T>;\n nodes: T[];\n parentId: string | null;\n treeItemChildIds: TreeItemChildIds;\n}\n\n/**\n * This util performantly builds a nested list of tree items from a giant flat\n * list of items by linking items together with the provided `parentId`. This\n * will also recursively build the tree and _hopefully_ all items will be added.\n *\n * @remarks \\@since 6.0.0 Updated to include the {@link TreeItemChildIds}\n */\nexport function buildTree<T extends TreeItemNode>(\n options: BuildTreeOptions<T>\n): readonly RenderableTreeItemNode<T>[] | undefined {\n const { sort, nodes, parentId, treeItemChildIds } = options;\n const childIds = treeItemChildIds.get(parentId) || new Set();\n const childItems: RenderableTreeItemNode<T>[] = [];\n\n // doing a \"reverse\" order filter/move so that the items array shrinks while\n // looping. This makes it so that the entire items array doesn't need to\n // continually be looped through as more items are added to the tree, only the\n // remaining items will have to be looped\n let i = nodes.length;\n while (i > 0) {\n i -= 1;\n if (nodes[i] && nodes[i].parentId === parentId) {\n const [item] = nodes.splice(i, 1);\n childIds.add(item.itemId);\n // shallow cloning so childItems doesn't get applied to the original data\n // set\n childItems.unshift({ ...item });\n }\n }\n\n if (!childItems.length) {\n return undefined;\n }\n\n treeItemChildIds.set(parentId, childIds);\n childItems.forEach((childItem) => {\n childItem.items = buildTree({\n sort,\n nodes,\n parentId: childItem.itemId,\n treeItemChildIds,\n });\n });\n\n return sort(childItems);\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface TreeItemOptions<T extends TreeItemNode> {\n data: TreeData<T>;\n sort: TreeItemSorter<T>;\n rootId: string | null;\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface TreeItems<T extends TreeItemNode> {\n items: readonly RenderableTreeItemNode<T>[];\n treeItemChildIds: TreeItemChildIds;\n}\n\n/**\n * This is mostly an internal hook, but can be used to build tree-like\n * data structures without the need of the `Tree` component.\n *\n * @remarks \\@since 6.0.0 converted to use an object argument instead of\n * multiple arguments. Also logs any orphaned items that do not have a parent\n */\nexport function useTreeItems<T extends TreeItemNode>(\n options: TreeItemOptions<T>\n): TreeItems<T> {\n const { data, sort, rootId } = options;\n\n return useMemo<TreeItems<T>>(() => {\n const values = Object.values(data);\n const treeItemChildIds = new Map<string, Set<string>>();\n const items = buildTree<T>({\n sort,\n nodes: values,\n parentId: rootId,\n treeItemChildIds,\n });\n\n if (process.env.NODE_ENV !== \"production\" && values.length) {\n /* eslint-disable no-console */\n console.warn(\"The following tree items are orphaned without a parent:\");\n console.warn(values.slice());\n }\n\n return {\n items: items || [],\n treeItemChildIds,\n };\n }, [data, rootId, sort]);\n}\n"],"names":["useMemo","buildTree","options","sort","nodes","parentId","treeItemChildIds","childIds","get","Set","childItems","i","length","item","splice","add","itemId","unshift","undefined","set","forEach","childItem","items","useTreeItems","data","rootId","values","Object","Map","process","env","NODE_ENV","console","warn","slice"],"mappings":"AAAA,SAASA,OAAO,QAAQ,QAAQ;AAuChC;;;;;;CAMC,GACD,OAAO,SAASC,UACdC,OAA4B;IAE5B,MAAM,EAAEC,IAAI,EAAEC,KAAK,EAAEC,QAAQ,EAAEC,gBAAgB,EAAE,GAAGJ;IACpD,MAAMK,WAAWD,iBAAiBE,GAAG,CAACH,aAAa,IAAII;IACvD,MAAMC,aAA0C,EAAE;IAElD,4EAA4E;IAC5E,wEAAwE;IACxE,8EAA8E;IAC9E,yCAAyC;IACzC,IAAIC,IAAIP,MAAMQ,MAAM;IACpB,MAAOD,IAAI,EAAG;QACZA,KAAK;QACL,IAAIP,KAAK,CAACO,EAAE,IAAIP,KAAK,CAACO,EAAE,CAACN,QAAQ,KAAKA,UAAU;YAC9C,MAAM,CAACQ,KAAK,GAAGT,MAAMU,MAAM,CAACH,GAAG;YAC/BJ,SAASQ,GAAG,CAACF,KAAKG,MAAM;YACxB,yEAAyE;YACzE,MAAM;YACNN,WAAWO,OAAO,CAAC;gBAAE,GAAGJ,IAAI;YAAC;QAC/B;IACF;IAEA,IAAI,CAACH,WAAWE,MAAM,EAAE;QACtB,OAAOM;IACT;IAEAZ,iBAAiBa,GAAG,CAACd,UAAUE;IAC/BG,WAAWU,OAAO,CAAC,CAACC;QAClBA,UAAUC,KAAK,GAAGrB,UAAU;YAC1BE;YACAC;YACAC,UAAUgB,UAAUL,MAAM;YAC1BV;QACF;IACF;IAEA,OAAOH,KAAKO;AACd;AAmBA;;;;;;CAMC,GACD,OAAO,SAASa,aACdrB,OAA2B;IAE3B,MAAM,EAAEsB,IAAI,EAAErB,IAAI,EAAEsB,MAAM,EAAE,GAAGvB;IAE/B,OAAOF,QAAsB;QAC3B,MAAM0B,SAASC,OAAOD,MAAM,CAACF;QAC7B,MAAMlB,mBAAmB,IAAIsB;QAC7B,MAAMN,QAAQrB,UAAa;YACzBE;YACAC,OAAOsB;YACPrB,UAAUoB;YACVnB;QACF;QAEA,IAAIuB,QAAQC,GAAG,CAACC,QAAQ,KAAK,gBAAgBL,OAAOd,MAAM,EAAE;YAC1D,6BAA6B,GAC7BoB,QAAQC,IAAI,CAAC;YACbD,QAAQC,IAAI,CAACP,OAAOQ,KAAK;QAC3B;QAEA,OAAO;YACLZ,OAAOA,SAAS,EAAE;YAClBhB;QACF;IACF,GAAG;QAACkB;QAAMC;QAAQtB;KAAK;AACzB"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/useTreeMovement.ts"],"sourcesContent":["\"use client\";\nimport type {\n FocusEventHandler,\n KeyboardEventHandler,\n MouseEventHandler,\n} from \"react\";\nimport { useRef } from \"react\";\nimport type { KeyboardMovementProviderImplementation } from \"../movement/types.js\";\nimport { useKeyboardMovementProvider } from \"../movement/useKeyboardMovementProvider.js\";\nimport { getNextFocusableIndex } from \"../movement/utils.js\";\nimport type { NonNullMutableRef } from \"../types.js\";\nimport type { TreeItemMetadataLookup } from \"./TreeProvider.js\";\nimport type { TreeData, TreeItemNode } from \"./types.js\";\nimport type { TreeExpansion } from \"./useTreeExpansion.js\";\nimport type { TreeItemChildIds } from \"./useTreeItems.js\";\n\n/**\n * This helps catch the edge case where the collapse transition has occurred for\n * a tree item group, but the user uses the `ArrowDown` key before it has\n * finished. So to do this:\n *\n * - find the parent group of the tree item\n * - find the tree item that controls the group (the element before the group)\n * - check if the `aria-expanded` state is `\"false\"` meaning it is considered\n * closed\n *\n * @internal\n * @remarks \\@since 6.0.0\n */\nconst isParentItemCollapsing = (item: HTMLElement): boolean =>\n item\n .closest(\"[role='group']\")\n ?.previousElementSibling?.getAttribute(\"aria-expanded\") === \"false\";\n\n/**\n * @remarks \\@since 6.0.0\n * @internal\n */\nconst getVisibleTreeItems = (\n container: HTMLElement\n): readonly HTMLElement[] => {\n const items = [\n ...container.querySelectorAll<HTMLElement>('[role=\"treeitem\"]'),\n ];\n\n return items.filter(\n (item) =>\n // do not include items that have a `hidden` parent group\n item.offsetParent &&\n // do not include items that are about to become hidden\n !isParentItemCollapsing(item)\n );\n};\n\n/**\n * @remarks \\@since 6.0.0\n * @internal\n */\ninterface TreeMovementOptions<T extends TreeItemNode> extends TreeExpansion {\n data: TreeData<T>;\n onClick: MouseEventHandler<HTMLUListElement> | undefined;\n onFocus: FocusEventHandler<HTMLUListElement> | undefined;\n onKeyDown: KeyboardEventHandler<HTMLUListElement> | undefined;\n selectedIds: ReadonlySet<string>;\n treeItemChildIds: TreeItemChildIds;\n}\n\n/**\n * @remarks \\@since 6.0.0\n * @internal\n */\ninterface TreeMovement\n extends KeyboardMovementProviderImplementation<HTMLUListElement> {\n /**\n * This will be mutated by the `TreeItem` component and used to handle\n * keyboard movement.\n */\n metadataLookup: NonNullMutableRef<TreeItemMetadataLookup>;\n}\n\n/**\n * @remarks \\@since 6.0.0\n * @internal\n */\nexport function useTreeMovement<T extends TreeItemNode>(\n options: TreeMovementOptions<T>\n): TreeMovement {\n const {\n onClick,\n onFocus,\n onKeyDown,\n data,\n expandedIds,\n selectedIds,\n treeItemChildIds,\n toggleTreeItemExpansion,\n expandMultipleTreeItems,\n } = options;\n\n const metadataLookup = useRef<TreeItemMetadataLookup>({\n expandable: {},\n disabledItems: {},\n elementToItem: {},\n itemToElement: {},\n });\n const movement = useKeyboardMovementProvider({\n onClick,\n onFocus,\n onKeyDown,\n extendKeyDown(movementData) {\n const { event, activeDescendantId, currentFocusIndex, setFocusIndex } =\n movementData;\n const { expandable, disabledItems, elementToItem, itemToElement } =\n metadataLookup.current;\n const itemId = elementToItem[activeDescendantId];\n const item = data[itemId];\n\n /* c8 ignore start */\n if (!item) {\n return;\n }\n /* c8 ignore end */\n\n const disabled = disabledItems[itemId];\n const expanded = expandedIds.has(itemId);\n\n let flagged = false;\n switch (event.key) {\n case \"ArrowLeft\":\n if (expanded && !disabled) {\n flagged = true;\n toggleTreeItemExpansion(itemId);\n } else if (item.parentId) {\n // do not flag for this case since setFocusIndex already does this\n const parentId = itemToElement[item.parentId];\n const focusables = getVisibleTreeItems(event.currentTarget);\n const index = focusables.findIndex(\n (element) => element.id === parentId\n );\n setFocusIndex(index, focusables);\n }\n\n break;\n case \"ArrowRight\":\n if (expandable[itemId] && !disabled) {\n if (!expanded) {\n flagged = true;\n toggleTreeItemExpansion(itemId);\n } else {\n // do not flag for this case since setFocusIndex already does this\n const focusables = getVisibleTreeItems(event.currentTarget);\n const index = getNextFocusableIndex({\n loopable: false,\n increment: true,\n focusables,\n includeDisabled: true,\n currentFocusIndex: currentFocusIndex.current,\n });\n\n setFocusIndex(index, focusables);\n }\n }\n\n break;\n case \"*\": {\n flagged = true;\n const itemIds = treeItemChildIds.get(item.parentId);\n if (itemIds) {\n const expandableIds = [...itemIds].filter(\n (itemId) => expandable[itemId]\n );\n if (expandableIds.length) {\n expandMultipleTreeItems(\n (prev) => new Set([...prev, ...expandableIds])\n );\n currentFocusIndex.current = -1;\n }\n }\n break;\n }\n }\n\n if (flagged) {\n event.stopPropagation();\n event.preventDefault();\n }\n },\n searchable: true,\n tabIndexBehavior: \"virtual\",\n getFocusableElements: getVisibleTreeItems,\n getDefaultFocusedIndex(options) {\n const { focusables } = options;\n const { elementToItem } = metadataLookup.current;\n\n return focusables.findIndex((element) =>\n selectedIds.has(elementToItem[element.id])\n );\n },\n });\n\n return {\n metadataLookup,\n ...movement,\n };\n}\n"],"names":["useRef","useKeyboardMovementProvider","getNextFocusableIndex","isParentItemCollapsing","item","closest","previousElementSibling","getAttribute","getVisibleTreeItems","container","items","querySelectorAll","filter","offsetParent","useTreeMovement","options","onClick","onFocus","onKeyDown","data","expandedIds","selectedIds","treeItemChildIds","toggleTreeItemExpansion","expandMultipleTreeItems","metadataLookup","expandable","disabledItems","elementToItem","itemToElement","movement","extendKeyDown","movementData","event","activeDescendantId","currentFocusIndex","setFocusIndex","current","itemId","disabled","expanded","has","flagged","key","parentId","focusables","currentTarget","index","findIndex","element","id","loopable","increment","includeDisabled","itemIds","get","expandableIds","length","prev","Set","stopPropagation","preventDefault","searchable","tabIndexBehavior","getFocusableElements","getDefaultFocusedIndex"],"mappings":"AAAA;AAMA,SAASA,MAAM,QAAQ,QAAQ;AAE/B,SAASC,2BAA2B,QAAQ,6CAA6C;AACzF,SAASC,qBAAqB,QAAQ,uBAAuB;AAO7D;;;;;;;;;;;;CAYC,GACD,MAAMC,yBAAyB,CAACC,OAC9BA,KACGC,OAAO,CAAC,mBACPC,wBAAwBC,aAAa,qBAAqB;AAEhE;;;CAGC,GACD,MAAMC,sBAAsB,CAC1BC;IAEA,MAAMC,QAAQ;WACTD,UAAUE,gBAAgB,CAAc;KAC5C;IAED,OAAOD,MAAME,MAAM,CACjB,CAACR,OACC,yDAAyD;QACzDA,KAAKS,YAAY,IACjB,uDAAuD;QACvD,CAACV,uBAAuBC;AAE9B;AA4BA;;;CAGC,GACD,OAAO,SAASU,gBACdC,OAA+B;IAE/B,MAAM,EACJC,OAAO,EACPC,OAAO,EACPC,SAAS,EACTC,IAAI,EACJC,WAAW,EACXC,WAAW,EACXC,gBAAgB,EAChBC,uBAAuB,EACvBC,uBAAuB,EACxB,GAAGT;IAEJ,MAAMU,iBAAiBzB,OAA+B;QACpD0B,YAAY,CAAC;QACbC,eAAe,CAAC;QAChBC,eAAe,CAAC;QAChBC,eAAe,CAAC;IAClB;IACA,MAAMC,WAAW7B,4BAA4B;QAC3Ce;QACAC;QACAC;QACAa,eAAcC,YAAY;YACxB,MAAM,EAAEC,KAAK,EAAEC,kBAAkB,EAAEC,iBAAiB,EAAEC,aAAa,EAAE,GACnEJ;YACF,MAAM,EAAEN,UAAU,EAAEC,aAAa,EAAEC,aAAa,EAAEC,aAAa,EAAE,GAC/DJ,eAAeY,OAAO;YACxB,MAAMC,SAASV,aAAa,CAACM,mBAAmB;YAChD,MAAM9B,OAAOe,IAAI,CAACmB,OAAO;YAEzB,mBAAmB,GACnB,IAAI,CAAClC,MAAM;gBACT;YACF;YACA,iBAAiB,GAEjB,MAAMmC,WAAWZ,aAAa,CAACW,OAAO;YACtC,MAAME,WAAWpB,YAAYqB,GAAG,CAACH;YAEjC,IAAII,UAAU;YACd,OAAQT,MAAMU,GAAG;gBACf,KAAK;oBACH,IAAIH,YAAY,CAACD,UAAU;wBACzBG,UAAU;wBACVnB,wBAAwBe;oBAC1B,OAAO,IAAIlC,KAAKwC,QAAQ,EAAE;wBACxB,kEAAkE;wBAClE,MAAMA,WAAWf,aAAa,CAACzB,KAAKwC,QAAQ,CAAC;wBAC7C,MAAMC,aAAarC,oBAAoByB,MAAMa,aAAa;wBAC1D,MAAMC,QAAQF,WAAWG,SAAS,CAChC,CAACC,UAAYA,QAAQC,EAAE,KAAKN;wBAE9BR,cAAcW,OAAOF;oBACvB;oBAEA;gBACF,KAAK;oBACH,IAAInB,UAAU,CAACY,OAAO,IAAI,CAACC,UAAU;wBACnC,IAAI,CAACC,UAAU;4BACbE,UAAU;4BACVnB,wBAAwBe;wBAC1B,OAAO;4BACL,kEAAkE;4BAClE,MAAMO,aAAarC,oBAAoByB,MAAMa,aAAa;4BAC1D,MAAMC,QAAQ7C,sBAAsB;gCAClCiD,UAAU;gCACVC,WAAW;gCACXP;gCACAQ,iBAAiB;gCACjBlB,mBAAmBA,kBAAkBE,OAAO;4BAC9C;4BAEAD,cAAcW,OAAOF;wBACvB;oBACF;oBAEA;gBACF,KAAK;oBAAK;wBACRH,UAAU;wBACV,MAAMY,UAAUhC,iBAAiBiC,GAAG,CAACnD,KAAKwC,QAAQ;wBAClD,IAAIU,SAAS;4BACX,MAAME,gBAAgB;mCAAIF;6BAAQ,CAAC1C,MAAM,CACvC,CAAC0B,SAAWZ,UAAU,CAACY,OAAO;4BAEhC,IAAIkB,cAAcC,MAAM,EAAE;gCACxBjC,wBACE,CAACkC,OAAS,IAAIC,IAAI;2CAAID;2CAASF;qCAAc;gCAE/CrB,kBAAkBE,OAAO,GAAG,CAAC;4BAC/B;wBACF;wBACA;oBACF;YACF;YAEA,IAAIK,SAAS;gBACXT,MAAM2B,eAAe;gBACrB3B,MAAM4B,cAAc;YACtB;QACF;QACAC,YAAY;QACZC,kBAAkB;QAClBC,sBAAsBxD;QACtByD,wBAAuBlD,OAAO;YAC5B,MAAM,EAAE8B,UAAU,EAAE,GAAG9B;YACvB,MAAM,EAAEa,aAAa,EAAE,GAAGH,eAAeY,OAAO;YAEhD,OAAOQ,WAAWG,SAAS,CAAC,CAACC,UAC3B5B,YAAYoB,GAAG,CAACb,aAAa,CAACqB,QAAQC,EAAE,CAAC;QAE7C;IACF;IAEA,OAAO;QACLzB;QACA,GAAGK,QAAQ;IACb;AACF"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/useTreeSelection.ts"],"sourcesContent":["\"use client\";\nimport { useCallback, useState } from \"react\";\nimport type { UseStateSetter } from \"../types.js\";\nimport type { TreeItemDefaultIds, TreeItemIdSet } from \"./types.js\";\n\n/**\n * @remarks \\@since 6.0.0 Renamed from `TreeItemSelection` and uses a Set\n * instead of a list to increase performance. Also renamed `onItemSelect` to\n * `toggleTreeItemSelection` and `onMultiItemSelect` to\n * `selectMultipleTreeItems`.\n */\nexport interface TreeSelection {\n /** @defaultValue `false` */\n multiSelect?: boolean;\n selectedIds: ReadonlySet<string>;\n toggleTreeItemSelection(itemId: string): void;\n selectMultipleTreeItems: UseStateSetter<TreeItemIdSet>;\n}\n\n/**\n * @remarks \\@since 6.0.0 Renamed from `useTreeItemSelection` and uses a Set\n * instead of a list to increase performance.\n */\nexport function useTreeSelection(\n defaultSelectedIds?: TreeItemDefaultIds,\n multiSelect = false\n): Required<TreeSelection> {\n const [selectedIds, setSelectedIds] = useState<TreeItemIdSet>(() => {\n const defaultIds =\n typeof defaultSelectedIds === \"function\"\n ? defaultSelectedIds()\n : defaultSelectedIds;\n\n return new Set(defaultIds);\n });\n\n const toggleTreeItemSelection = useCallback(\n (itemId: string) => {\n setSelectedIds((selectedIds) => {\n if (!multiSelect) {\n return selectedIds.has(itemId) ? selectedIds : new Set([itemId]);\n }\n\n const nextSelectedIds = new Set(selectedIds);\n if (selectedIds.has(itemId)) {\n nextSelectedIds.delete(itemId);\n } else {\n nextSelectedIds.add(itemId);\n }\n\n return nextSelectedIds;\n });\n },\n [multiSelect]\n );\n\n return {\n selectedIds,\n multiSelect,\n toggleTreeItemSelection,\n selectMultipleTreeItems: setSelectedIds,\n };\n}\n"],"names":["useCallback","useState","useTreeSelection","defaultSelectedIds","multiSelect","selectedIds","setSelectedIds","defaultIds","Set","toggleTreeItemSelection","itemId","has","nextSelectedIds","delete","add","selectMultipleTreeItems"],"mappings":"AAAA;AACA,SAASA,WAAW,EAAEC,QAAQ,QAAQ,QAAQ;AAkB9C;;;CAGC,GACD,OAAO,SAASC,iBACdC,kBAAuC,EACvCC,cAAc,KAAK;IAEnB,MAAM,CAACC,aAAaC,eAAe,GAAGL,SAAwB;QAC5D,MAAMM,aACJ,OAAOJ,uBAAuB,aAC1BA,uBACAA;QAEN,OAAO,IAAIK,IAAID;IACjB;IAEA,MAAME,0BAA0BT,YAC9B,CAACU;QACCJ,eAAe,CAACD;YACd,IAAI,CAACD,aAAa;gBAChB,OAAOC,YAAYM,GAAG,CAACD,UAAUL,cAAc,IAAIG,IAAI;oBAACE;iBAAO;YACjE;YAEA,MAAME,kBAAkB,IAAIJ,IAAIH;YAChC,IAAIA,YAAYM,GAAG,CAACD,SAAS;gBAC3BE,gBAAgBC,MAAM,CAACH;YACzB,OAAO;gBACLE,gBAAgBE,GAAG,CAACJ;YACtB;YAEA,OAAOE;QACT;IACF,GACA;QAACR;KAAY;IAGf,OAAO;QACLC;QACAD;QACAK;QACAM,yBAAyBT;IAC3B;AACF"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/tree/utils.ts"],"sourcesContent":["import type { TreeItemNode, TreeData, DefaultTreeItemNode } from \"./types.js\";\n\n/**\n * This will get all the items from the provided itemId up to the root of the\n * tree that can be used for drag and drop behavior or building a breadcrumb\n * list.\n *\n * @param data - The flattened tree data to navigate.\n * @param itemId - The item id to start the search at.\n * @returns an ordered list of the current item followed by all the direct\n * parents of that item.\n * @remarks \\@since 6.0.0 Renamed from `getItemsFrom` to `getTreeItemsFrom`.\n */\nexport function getTreeItemsFrom<T extends TreeItemNode = DefaultTreeItemNode>(\n data: TreeData<T>,\n itemId: string | null\n): readonly T[] {\n const items: T[] = [];\n let currentId = itemId;\n while (currentId) {\n const item = data[currentId];\n currentId = item?.parentId ?? null;\n if (item) {\n items.push(item);\n }\n }\n\n return items;\n}\n\n/**\n * Gets all the child items for a specific parent item id. If the `recursive`\n * argument is enabled, all children of the items will also be returned instead\n * of only the top level items.\n *\n * @param data - Either the flattened tree data or a list of all the tree data\n * to iterate over\n * @param parentId - The parent id to get children of\n * @param recursive - Boolean if the children's children should also be returned\n * @returns a list of all the items for a specific parent item id. Note: if the\n * recursive param is enabled, the list will be ordered so that the children of\n * a item will appear before the next item at the same level. So you either need\n * to sort by `parentId` or something else if you want a specific order.\n * @remarks \\@since 6.0.0 Renamed from `getChildItems` to `getChildTreeItems`.\n */\nexport function getChildTreeItems<T extends TreeItemNode = DefaultTreeItemNode>(\n data: TreeData<T> | readonly T[],\n parentId: string | null,\n recursive = false\n): readonly T[] {\n const items = Array.isArray(data) ? data : Object.values(data);\n\n return items.reduce<T[]>((list, item) => {\n if (parentId !== item.parentId) {\n return list;\n }\n\n return [\n ...list,\n item,\n ...(recursive ? getChildTreeItems(items, item.itemId, recursive) : []),\n ];\n }, []);\n}\n"],"names":["getTreeItemsFrom","data","itemId","items","currentId","item","parentId","push","getChildTreeItems","recursive","Array","isArray","Object","values","reduce","list"],"mappings":"AAEA;;;;;;;;;;CAUC,GACD,OAAO,SAASA,iBACdC,IAAiB,EACjBC,MAAqB;IAErB,MAAMC,QAAa,EAAE;IACrB,IAAIC,YAAYF;IAChB,MAAOE,UAAW;QAChB,MAAMC,OAAOJ,IAAI,CAACG,UAAU;QAC5BA,YAAYC,MAAMC,YAAY;QAC9B,IAAID,MAAM;YACRF,MAAMI,IAAI,CAACF;QACb;IACF;IAEA,OAAOF;AACT;AAEA;;;;;;;;;;;;;;CAcC,GACD,OAAO,SAASK,kBACdP,IAAgC,EAChCK,QAAuB,EACvBG,YAAY,KAAK;IAEjB,MAAMN,QAAQO,MAAMC,OAAO,CAACV,QAAQA,OAAOW,OAAOC,MAAM,CAACZ;IAEzD,OAAOE,MAAMW,MAAM,CAAM,CAACC,MAAMV;QAC9B,IAAIC,aAAaD,KAAKC,QAAQ,EAAE;YAC9B,OAAOS;QACT;QAEA,OAAO;eACFA;YACHV;eACII,YAAYD,kBAAkBL,OAAOE,KAAKH,MAAM,EAAEO,aAAa,EAAE;SACtE;IACH,GAAG,EAAE;AACP"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * @remarks \@since 6.0.0
3
+ */ export { };
4
+
5
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/types.ts"],"sourcesContent":["import type { Dispatch, ReactElement, Ref, SetStateAction } from \"react\";\n\n/**\n * A helper type that allows an optional `ref` to also be applied with a props\n * object even though a `ref` isn't a real prop.\n */\nexport type PropsWithRef<\n Props extends {},\n Element extends HTMLElement,\n> = Props & {\n /**\n * An optional ref that can be applied.\n */\n ref?: Ref<Element>;\n};\n\n/**\n * A simple type that can be used for different components that clone a\n * `className` into a child component.\n */\nexport type ClassNameCloneableChild<T = {}> = ReactElement<\n T & { className?: string }\n>;\n\n/**\n * This type allows you to require at least one of the provided keys. This is\n * super helpful for things like `aria-label` or `aria-labelledby` when it's\n * required for a11y.\n *\n * @see https://stackoverflow.com/questions/40510611/typescript-interface-require-one-of-two-properties-to-exist/49725198#49725198\n */\nexport type RequireAtLeastOne<T, Keys extends keyof T = keyof T> = Pick<\n T,\n Exclude<keyof T, Keys>\n> &\n {\n [K in Keys]-?: Required<Pick<T, K>> & Partial<Pick<T, Exclude<Keys, K>>>;\n }[Keys];\n\nexport interface LabelA11y {\n \"aria-label\"?: string;\n \"aria-labelledby\"?: string;\n}\n\n/**\n * A small accessibility helper to ensure that either `aria-label` or\n * `aria-labelledby` have been provided to a component.\n *\n * @example\n * Simple Example\n * ```ts\n * import type { HTMLAttributes, ReactElement } from \"react\";\n * import type { LabelRequiredForA11y } from \"@react-md/core\";\n *\n * type Props = LabelRequiredForA11y<HTMLAttributes<HTMLDivElement>>;\n *\n * function Component(props: Props): ReactElement {\n * return <div {...props} />;\n * }\n *\n * const test1 = <Component />\n * // ^ type error\n * const test2 = <Component aria-label=\"Label\" />\n * const test3 = <Component aria-labelledby=\"some-other-id\" />\n * ```\n */\nexport type LabelRequiredForA11y<Props extends LabelA11y> = RequireAtLeastOne<\n Props,\n keyof LabelA11y\n>;\n\n/**\n * @remarks \\@since 5.0.0\n * @internal\n */\nexport interface NonNullRef<T> {\n readonly current: T;\n}\n\n/**\n * @remarks \\@since 6.0.0\n * @internal\n */\nexport interface NonNullMutableRef<T> {\n current: T;\n}\n\n/** @remarks \\@since 6.0.0 */\nexport type HtmlTagName = keyof JSX.IntrinsicElements;\n\n/**\n * A function to get a string from a generic item.\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 * const extractor: TextExtractor<Item> = (item) => item.name;\n * ```\n * @remarks \\@since 6.0.0\n */\nexport type TextExtractor<T> = (item: T) => string;\n\n/**\n * @remarks \\@since 6.0.0\n * @internal\n */\nexport type UseStateSetter<T> = Dispatch<SetStateAction<T>>;\n\n/**\n * @remarks \\@since 6.0.0\n * @internal\n */\nexport type UseStateInitializer<T> = T | (() => T);\n\n/**\n * @example\n * ```ts\n * type Visibility = UseStateObject<\"visible\", boolean>;\n * // type Visibility = {\n * // visible: boolean;\n * // setVisible: UseStateSetter<boolean>\n * // }\n *\n * type AnotherOne = UseStateObject<\"renderAsSheet\", RenderMenuAsSheet>;\n * // type AnotherOne = {\n * // renderAsSheet: RenderMenuAsSheet;\n * // setRenderAsSheet: UseStateSetter<RenderMenuAsSheet>;\n * // }\n * ```\n * @remarks \\@since 6.0.0\n * @internal\n */\nexport type UseStateObject<Name extends string, Value> = {\n [key in Name]: Value;\n} & {\n [key in `set${Capitalize<Name>}`]: UseStateSetter<Value>;\n};\n\n/**\n * @example\n * ```ts\n * interface Example {\n * value: number;\n * setValue: UseStateSetter<number>;\n * }\n *\n * type WithPrefix = RenameKeysWithPrefix<Example, \"thumb1\">;\n * // type WithPrefix = {\n * // thumb1Value: number;\n * // thumb1SetValue: UseStateSetter<number>;\n * // }\n * ```\n *\n * @remarks \\@since 6.0.0\n * @internal\n */\nexport type RenameKeysWithPrefix<T, Prefix extends string> = {\n [Key in keyof T & string as `${Prefix}${Capitalize<Key>}`]: T[Key];\n};\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport type CssPosition = \"fixed\" | \"sticky\" | \"static\";\n\n/**\n * @remarks \\@since 6.0.0\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type AnyFunction = (...args: any[]) => any | void;\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface ElementSize {\n height: number;\n width: number;\n}\n"],"names":[],"mappings":"AAiLA;;CAEC,GACD,WAGC"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/typography/SrOnly.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport {\n Typography,\n type CustomTypographyComponent,\n type TypographyHTMLElement,\n type TypographyProps,\n} from \"./Typography.js\";\nimport { cssUtils } from \"../cssUtils.js\";\n\nexport interface SrOnlyProps extends TypographyProps {\n /** @defaultValue `\"span\"` */\n as?: CustomTypographyComponent;\n\n /**\n * Set this to `true` if the content should only be screen reader only text on\n * phones. This is useful for only displaying an icon on phones when there is\n * limited space and then displaying an icon and text on larger devices.\n *\n * @defaultValue `false`\n */\n phoneOnly?: boolean;\n\n /**\n * Set this to `true` if the element should be keyboard focusable.\n *\n * @defaultValue `false`\n */\n focusable?: boolean;\n}\n\n/**\n * **Server Component**\n *\n * @example\n * Simple Example\n * ```tsx\n * import { SrOnly } from \"@react-md/core\";\n * import type { ReactElement } from \"react\";\n *\n * function Example(): ReactElement {\n * return (\n * <>\n * <SrOnly>\n * I am only visible to screen readers.\n * </SrOnly>\n * <SrOnly focusable>\n * I am only visible to screen readers but can be focused.\n * </SrOnly>\n * </>\n * );\n * }\n * ```\n */\nexport const SrOnly = forwardRef<TypographyHTMLElement, SrOnlyProps>(\n function SrOnly(props, ref) {\n const {\n as = \"span\",\n className,\n phoneOnly,\n focusable,\n children,\n tabIndex,\n ...remaining\n } = props;\n\n return (\n <Typography\n {...remaining}\n as={as}\n ref={ref}\n tabIndex={tabIndex ?? (focusable ? 0 : undefined)}\n className={cssUtils({\n srOnly: focusable ? \"focusable\" : phoneOnly ? \"phone\" : true,\n className,\n })}\n >\n {children}\n </Typography>\n );\n }\n);\n"],"names":["forwardRef","Typography","cssUtils","SrOnly","props","ref","as","className","phoneOnly","focusable","children","tabIndex","remaining","undefined","srOnly"],"mappings":";AAAA,SAASA,UAAU,QAAQ,QAAQ;AACnC,SACEC,UAAU,QAIL,kBAAkB;AACzB,SAASC,QAAQ,QAAQ,iBAAiB;AAuB1C;;;;;;;;;;;;;;;;;;;;;;CAsBC,GACD,OAAO,MAAMC,uBAASH,WACpB,SAASG,OAAOC,KAAK,EAAEC,GAAG;IACxB,MAAM,EACJC,KAAK,MAAM,EACXC,SAAS,EACTC,SAAS,EACTC,SAAS,EACTC,QAAQ,EACRC,QAAQ,EACR,GAAGC,WACJ,GAAGR;IAEJ,qBACE,KAACH;QACE,GAAGW,SAAS;QACbN,IAAIA;QACJD,KAAKA;QACLM,UAAUA,YAAaF,CAAAA,YAAY,IAAII,SAAQ;QAC/CN,WAAWL,SAAS;YAClBY,QAAQL,YAAY,cAAcD,YAAY,UAAU;YACxDD;QACF;kBAECG;;AAGP,GACA"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/typography/TextContainer.tsx"],"sourcesContent":["import { cnb } from \"cnbuilder\";\nimport { forwardRef, type HTMLAttributes } from \"react\";\nimport { bem } from \"../utils/bem.js\";\n\ndeclare module \"react\" {\n interface CSSProperties {\n \"--rmd-line-length\"?: string | number;\n \"--rmd-text-container-padding\"?: string | number;\n }\n}\n\nconst styles = bem(\"rmd-text-container\");\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface TextContainerClassNameOptions {\n /**\n * An optional className to merge with typography text container styles.\n */\n className?: string;\n}\n\n/**\n * @example\n * Simple Example\n * ```tsx\n * import { textContainer, Typography } from \"@react-md/core\";\n *\n * function Example() {\n * return (\n * <main className={textContainer()}>\n * <Typography type=\"headline-1\">Heading</Typography>\n * <Typography>\n * Pretend this is a giant paragraph of text that wraps multiple lines.\n * </Typography>\n * <Typography>\n * Pretend this is another giant paragraph of text that wraps multiple\n * lines.\n * </Typography>\n * </main>\n * ):\n * }\n * ```\n *\n * @remarks \\@since 6.0.0\n */\nexport function textContainer(\n options: TextContainerClassNameOptions = {}\n): string {\n const { className } = options;\n\n return cnb(styles(), className);\n}\n\n/**\n * @remarks \\@since 6.0.0 Removed the `size` option since there is no longer a\n * different line-length for mobile and desktop.\n */\nexport interface TextContainerProps\n extends HTMLAttributes<HTMLDivElement>,\n TextContainerClassNameOptions {}\n\n/**\n * **Server Component**\n *\n * This component should be used to render text based content with an\n * appropriate max line length to optimize legibility.\n *\n * @example\n * Simple Example\n * ```tsx\n * import { TextContainer, Typography } from \"@react-md/core\";\n *\n * function Example() {\n * return (\n * <TextContainer>\n * <Typography type=\"headline-1\">Heading</Typography>\n * <Typography>\n * Pretend this is a giant paragraph of text that wraps multiple lines.\n * </Typography>\n * <Typography>\n * Pretend this is another giant paragraph of text that wraps multiple\n * lines.\n * </Typography>\n * </TextContainer>\n * );\n * }\n * ```\n *\n * @see {@link textContainer} If you only want to apply this class to an\n * element.\n * @remarks \\@since 6.0.0 Removed the `size` option since there is no longer a\n * different line-length for mobile and desktop.\n */\nexport const TextContainer = forwardRef<HTMLDivElement, TextContainerProps>(\n function TextContainer(props, ref) {\n const { className, children, ...remaining } = props;\n\n return (\n <div {...remaining} ref={ref} className={textContainer({ className })}>\n {children}\n </div>\n );\n }\n);\n"],"names":["cnb","forwardRef","bem","styles","textContainer","options","className","TextContainer","props","ref","children","remaining","div"],"mappings":";AAAA,SAASA,GAAG,QAAQ,YAAY;AAChC,SAASC,UAAU,QAA6B,QAAQ;AACxD,SAASC,GAAG,QAAQ,kBAAkB;AAStC,MAAMC,SAASD,IAAI;AAYnB;;;;;;;;;;;;;;;;;;;;;;;CAuBC,GACD,OAAO,SAASE,cACdC,UAAyC,CAAC,CAAC;IAE3C,MAAM,EAAEC,SAAS,EAAE,GAAGD;IAEtB,OAAOL,IAAIG,UAAUG;AACvB;AAUA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+BC,GACD,OAAO,MAAMC,8BAAgBN,WAC3B,SAASM,cAAcC,KAAK,EAAEC,GAAG;IAC/B,MAAM,EAAEH,SAAS,EAAEI,QAAQ,EAAE,GAAGC,WAAW,GAAGH;IAE9C,qBACE,KAACI;QAAK,GAAGD,SAAS;QAAEF,KAAKA;QAAKH,WAAWF,cAAc;YAAEE;QAAU;kBAChEI;;AAGP,GACA"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/typography/Typography.tsx"],"sourcesContent":["import { cnb } from \"cnbuilder\";\nimport {\n forwardRef,\n type ElementType,\n type HTMLAttributes,\n type ReactElement,\n} from \"react\";\nimport { cssUtils, type TextCssUtilsOptions } from \"../cssUtils.js\";\n\n/**\n * A union of all the material design provided typography styles. When used with\n * the Typography component, this will generate the correct typography className\n * to apply and determine what component to be rendered as if none was provided.\n *\n * @remarks \\@since 4.0.0\n */\nexport type TypographyType =\n | \"headline-1\"\n | \"headline-2\"\n | \"headline-3\"\n | \"headline-4\"\n | \"headline-5\"\n | \"headline-6\"\n | \"subtitle-1\"\n | \"subtitle-2\"\n | \"body-1\"\n | \"body-2\"\n | \"caption\"\n | \"overline\";\n\n/** @remarks \\@since 6.0.0 */\nexport interface TypographyClassNameOptions extends TextCssUtilsOptions {\n className?: string;\n\n /**\n * @see {@link TypographyType}\n * @defaultValue `\"body-1\"`\n */\n type?: TypographyType;\n}\n\n/** @remarks \\@since 6.0.0 */\nexport type NullableTypographyClassNameOptions = Omit<\n TypographyClassNameOptions,\n \"type\"\n> & {\n /**\n * When using the {@link typography} class name utility, the `type` can be set\n * to `null` to inherit font.\n *\n * @see {@link TypographyType}\n * @defaultValue `\"body-1\"`\n */\n type?: TypographyType | null;\n};\n\n/**\n * Get a typography class name based on different typography options. This is\n * only useful if you are unable to use the {@link Typography} component for\n * some reason.\n *\n * @example\n * Simple Example\n * ```ts\n * import { getTypographyClassName } from \"@react-md/core\";\n *\n * function Example() {\n * return (\n * <>\n * <h1 className={getTypographyClassName({ type: \"headline-1\" })} />\n * <h2 className={getTypographyClassName({ type: \"headline-2\" })} />\n * <h3 className={getTypographyClassName({ type: \"headline-3\" })} />\n * <h4 className={getTypographyClassName({ type: \"headline-4\" })} />\n * <h5 className={getTypographyClassName({ type: \"headline-5\" })} />\n * <h6 className={getTypographyClassName({ type: \"headline-6\" })} />\n * <h5 className={getTypographyClassName({ type: \"subtitle-1\" })} />\n * <h6 className={getTypographyClassName({ type: \"subtitle-2\" })} />\n * <p className={getTypographyClassName()} />\n * <p className={getTypographyClassName({ type \"body-1\" })} />\n * <p className={getTypographyClassName({ type \"body-1\" })} />\n * <caption className={getTypographyClassName({ type: \"caption\" })} />\n * <span className={getTypographyClassName({ type: \"overline\" })} />\n * </>\n * );\n * }\n * ```\n *\n * @example\n * Applying Additional Styles\n * ```ts\n * import { getTypography } from \"@react-md/core\";\n *\n * function Example() {\n * return (\n * <>\n * <h1\n * // only maintain the default margin-bottom\n * className={getTypographyClassName({\n * type: \"headline-1\",\n * margin: \"bottom\",\n * })}\n * />\n *\n * <h2\n * // remove all default margin\n * className={getTypographyClassName({\n * type: \"headline-2\",\n * margin: \"none\",\n * })}\n * />\n *\n * <h3\n * // only maintain the default margin-top\n * className={getTypographyClassName({\n * type: \"headline-3\",\n * margin: \"top\",\n * })}\n * />\n *\n * <p\n * // center the text, set to bold, and only maintain default margin-bottom\n * className={getTypographyClassName({\n * type \"subtitle-1\",\n * align: \"center\",\n * margin: \"bottom\",\n * })}\n * />\n * </>\n * );\n * }\n * ```\n *\n * @see {@link Typography}\n * @param options - An optional object of options used to create the typography\n * class name.\n * @returns a typography class name string\n * @remarks \\@since 6.0.0\n */\nexport function typography(\n options: NullableTypographyClassNameOptions = {}\n): string {\n const { type = \"body-1\" } = options;\n\n // using `&&` instead of `bem` since the latest version of typescript does not\n // support setting the same object key (empty string)\n return cnb(\n \"rmd-typography\",\n type && `rmd-typography--${type}`,\n cssUtils(options)\n );\n}\n\n/**\n * A union of the default supported elements that the `Typography` component can\n * be rendered as. This is mostly used for adding the correct `HTMLAttributes`\n * and enabling the forward ref.\n *\n * @remarks \\@since 4.0.0\n */\nexport type TypographyHTMLElement =\n | HTMLHeadingElement\n | HTMLParagraphElement\n | HTMLSpanElement\n | HTMLDivElement\n | HTMLAnchorElement\n | HTMLBodyElement\n | HTMLHtmlElement;\n\n/** @remarks \\@since 6.0.0 */\nexport type CustomTypographyComponent = ElementType<\n HTMLAttributes<TypographyHTMLElement> & { className: string }\n>;\n\n/** @internal */\nfunction getComponent(\n as: CustomTypographyComponent | undefined,\n type: TypographyType\n): ElementType {\n if (as) {\n return as;\n }\n\n switch (type) {\n case \"headline-1\":\n return \"h1\";\n case \"headline-2\":\n return \"h2\";\n case \"headline-3\":\n return \"h3\";\n case \"headline-4\":\n return \"h4\";\n case \"headline-5\":\n return \"h5\";\n case \"headline-6\":\n case \"subtitle-1\":\n case \"subtitle-2\":\n return \"h6\";\n case \"body-1\":\n case \"body-2\":\n return \"p\";\n case \"caption\":\n return \"caption\";\n default:\n return \"span\";\n }\n}\n\nexport interface TypographyProps\n extends HTMLAttributes<TypographyHTMLElement>,\n TypographyClassNameOptions {\n /**\n * The component to render as when the children are not a render function. If\n * this prop is omitted, the component will be determined by the `type` prop\n * where:\n *\n * - `\"headline-1\" -> <h1>`\n * - `\"headline-2\" -> <h2>`\n * - `\"headline-3\" -> <h3>`\n * - `\"headline-4\" -> <h4>`\n * - `\"headline-5\" -> <h5>`\n * - `\"headline-6\" -> <h6>`\n * - `\"subtitle-1\" -> <h5>`\n * - `\"subtitle-2\" -> <h6>`\n * - `\"body-1\" -> <p>`\n * - `\"body-2\" -> <p>`\n * - `\"caption\" -> <caption>`\n * - `\"overline\" -> <span>`\n */\n as?: CustomTypographyComponent;\n}\n\n/**\n * **Server Component**\n *\n * Render text with one of the material design typography styles applied and\n * optional styles like font-weight, font-style, text color, etc.\n *\n * @example\n * All Example\n * ```tsx\n * import { Typography } from \"@react-md/core\":\n *\n * export function Example() {\n * return (\n * <>\n * <Typography type=\"headline-1\">Headline 1</Typography>\n * <Typography type=\"headline-2\">Headline 2</Typography>\n * <Typography type=\"headline-3\">Headline 3</Typography>\n * <Typography type=\"headline-4\">Headline 4</Typography>\n * <Typography type=\"headline-5\">Headline 5</Typography>\n * <Typography type=\"headline-6\">Headline 6</Typography>\n * <Typography type=\"subtitle-1\">Subtitle 1</Typography>\n * <Typography type=\"subtitle-2\">Subtitle 2</Typography>\n * <Typography>\n * A paragraph of text.\n * </Typography>\n * <Typography type=\"body-1\">\n * A paragraph of text.\n * </Typography>\n * <Typography type=\"body-2\">\n * Another paragraph of text.\n * </Typography>\n * <Typography type=\"caption\" component=\"h5\">\n * Caption text\n * </Typography>\n * <Typography type=\"overline\" component=\"h5\">\n * Overline text\n * </Typography>\n * </>\n * ):\n * }\n * ```\n */\nexport const Typography = forwardRef<TypographyHTMLElement, TypographyProps>(\n function Typography(props, ref): ReactElement {\n const {\n as,\n type = \"body-1\",\n className,\n margin,\n fontStyle,\n fontWeight,\n textAlign,\n textColor,\n textDecoration,\n textTransform,\n textOverflow,\n children,\n ...remaining\n } = props;\n\n const Component = getComponent(as, type);\n return (\n <Component\n {...remaining}\n ref={ref}\n className={typography({\n type,\n margin,\n fontStyle,\n fontWeight,\n textAlign,\n textColor,\n textDecoration,\n textTransform,\n textOverflow,\n className,\n })}\n >\n {children}\n </Component>\n );\n }\n);\n"],"names":["cnb","forwardRef","cssUtils","typography","options","type","getComponent","as","Typography","props","ref","className","margin","fontStyle","fontWeight","textAlign","textColor","textDecoration","textTransform","textOverflow","children","remaining","Component"],"mappings":";AAAA,SAASA,GAAG,QAAQ,YAAY;AAChC,SACEC,UAAU,QAIL,QAAQ;AACf,SAASC,QAAQ,QAAkC,iBAAiB;AAiDpE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAiFC,GACD,OAAO,SAASC,WACdC,UAA8C,CAAC,CAAC;IAEhD,MAAM,EAAEC,OAAO,QAAQ,EAAE,GAAGD;IAE5B,8EAA8E;IAC9E,qDAAqD;IACrD,OAAOJ,IACL,kBACAK,QAAQ,CAAC,gBAAgB,EAAEA,KAAK,CAAC,EACjCH,SAASE;AAEb;AAuBA,cAAc,GACd,SAASE,aACPC,EAAyC,EACzCF,IAAoB;IAEpB,IAAIE,IAAI;QACN,OAAOA;IACT;IAEA,OAAQF;QACN,KAAK;YACH,OAAO;QACT,KAAK;YACH,OAAO;QACT,KAAK;YACH,OAAO;QACT,KAAK;YACH,OAAO;QACT,KAAK;YACH,OAAO;QACT,KAAK;QACL,KAAK;QACL,KAAK;YACH,OAAO;QACT,KAAK;QACL,KAAK;YACH,OAAO;QACT,KAAK;YACH,OAAO;QACT;YACE,OAAO;IACX;AACF;AA0BA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyCC,GACD,OAAO,MAAMG,2BAAaP,WACxB,SAASO,WAAWC,KAAK,EAAEC,GAAG;IAC5B,MAAM,EACJH,EAAE,EACFF,OAAO,QAAQ,EACfM,SAAS,EACTC,MAAM,EACNC,SAAS,EACTC,UAAU,EACVC,SAAS,EACTC,SAAS,EACTC,cAAc,EACdC,aAAa,EACbC,YAAY,EACZC,QAAQ,EACR,GAAGC,WACJ,GAAGZ;IAEJ,MAAMa,YAAYhB,aAAaC,IAAIF;IACnC,qBACE,KAACiB;QACE,GAAGD,SAAS;QACbX,KAAKA;QACLC,WAAWR,WAAW;YACpBE;YACAO;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAR;QACF;kBAECS;;AAGP,GACA"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/typography/WritingDirectionProvider.tsx"],"sourcesContent":["\"use client\";\nimport {\n Children,\n cloneElement,\n createContext,\n useCallback,\n useContext,\n useEffect,\n useMemo,\n useState,\n type ReactElement,\n} from \"react\";\nimport { type UseStateInitializer } from \"../types.js\";\n\n/**\n * Note: unlike the `dir` DOM attribute, the `\"auto\"` value is not supported.\n *\n * @remarks \\@since 6.0.0\n */\nexport type Dir = \"ltr\" | \"rtl\";\n\n/** @remarks \\@since 6.0.0 */\nexport type DefaultDir = UseStateInitializer<Dir>;\n\n/** @remarks \\@since 2.3.0 */\nexport interface WritingDirectionContext {\n /**\n * The current writing direction that is being inherited.\n */\n dir: Dir;\n\n /**\n * Toggles the current writing direction for the first parent `Dir` component.\n */\n toggleDir(): void;\n}\n\n/** @internal */\ninterface InheritableContext extends WritingDirectionContext {\n root: boolean;\n}\n\nconst context = createContext<InheritableContext>({\n root: true,\n dir: \"ltr\",\n toggleDir: () => {\n if (process.env.NODE_ENV !== \"production\") {\n throw new Error(\n \"Tried to toggle the current writing direction without initializing the `Dir` component.\"\n );\n }\n },\n});\ncontext.displayName = \"WritingDirection\";\nconst { Provider } = context;\n\n/**\n * Gets the writing direction context which provides access to the current `dir`\n * and a `toggleDir` function.\n *\n * @example\n * Manually Changing the Writing Direction\n * ```tsx\n * import { useDir } from \"@react-md/core\";\n *\n * function Example() {\n * const { dir, toggleDir } = useDir();\n *\n * return (\n * <>\n * <p>{`The current dir is: \"${dir}\"`}</p>\n * <button type=\"button\" onClick={toggleDir}>Toggle</button>\n * </>\n * );\n * }\n * ```\n *\n * @remarks \\@since 6.0.0\n */\nexport function useDir(): Readonly<WritingDirectionContext> {\n const { root: _root, ...current } = useContext(context);\n return current;\n}\n\n/** @remarks \\@since 6.0.0 */\nexport interface WritingDirectionProviderProps {\n /**\n * A single ReactElement child. If the `WritingDirection` has a parent\n * `WritingDirection`, the child will have the `dir` prop cloned into this\n * element.\n */\n children: ReactElement<{ dir?: Dir }>;\n\n /**\n * The default writing direction for your app or a subtree. To change the\n * current writing direction, use the `useDir` hook to get access to the\n * current `dir` and the `toggleDir` function.\n *\n * @defaultValue `\"ltr\"`\n * @see {@link DEFAULT_WRITING_DIRECTION}\n */\n defaultDir?: DefaultDir;\n}\n\n/**\n * In the browser, this will default to the `<html>`'s `dir` value if one\n * exists. If the `dir` attribute does not exist, it will default to `\"ltr\"`.\n *\n * In node environments, this will default to `\"ltr\"`.\n *\n * @remarks \\@since 6.0.0\n */\nexport const DEFAULT_WRITING_DIRECTION = (): Dir => {\n let dir: Dir = \"ltr\";\n if (typeof document !== \"undefined\") {\n const rootDir = document.documentElement.getAttribute(\"dir\");\n dir = rootDir === \"rtl\" ? \"rtl\" : \"ltr\";\n }\n\n return dir;\n};\n\n/**\n * **Client Component**\n *\n * The `WritingDirection` component is used to handle the current writing\n * direction within your app as well as conditionally updating the writing\n * direction for small sections in your app. When this component is used for the\n * first time near the root of your React component tree, the current direction\n * will be applied to the root `<html>` element. Otherwise the current dir will\n * be cloned into the child element so it can be passed as a prop.\n *\n * Note: Since the `dir` is cloned into the child element, you need to make sure\n * that the child is either a DOM element or the `dir` prop is passed from your\n * custom component.\n *\n * @example\n * Root Setup\n * ```tsx\n * import { createRoot } from \"react-dom/client\";\n * import { WritingDirection } from \"@react-md/core\";\n * import App from \"./App.js\":\n *\n * const container = document.getElementById(\"root\");\n * const root = createRoot(container);\n *\n * root.render(\n * <WritingDirection>\n * <App />\n * </WritingDirection>\n * );\n * ```\n *\n * @example\n * Supporting RTL Languages\n * ```tsx\n * import { createRoot } from \"react-dom/client\";\n * import { WritingDirection } from \"@react-md/core\";\n * import type { Dir } from \"@react-md/core\";\n * import App from \"./App.js\":\n *\n * const container = document.getElementById(\"root\");\n * const root = createRoot(container);\n *\n * // see https://meta.wikimedia.org/wiki/Template:List_of_language_names_ordered_by_code\n * const SUPPORTED_RTL_LANGUAGES = [\n * \"ar\",\n * \"arc\",\n * \"ckb\",\n * \"dv\",\n * \"fa\",\n * \"ha\",\n * \"he\",\n * \"khw\",\n * \"ks\",\n * \"ps\",\n * \"sd\",\n * \"ur\",\n * \"uz_AF\",\n * \"ti\",\n * ];\n *\n * const defaultDir = (): Dir => {\n * if (SUPPORTED_RTL_LANGUAGES.includes(navigator.language)) {\n * return \"rtl\"\n * }\n *\n * return \"ltr\";\n * }\n *\n * root.render(\n * <WritingDirection defaultDir={defaultDir}>\n * <App />\n * </WritingDirection>\n * );\n * ```\n *\n * @remarks \\@since 6.0.0\n */\nexport function WritingDirectionProvider(\n props: WritingDirectionProviderProps\n): ReactElement {\n const { children, defaultDir = DEFAULT_WRITING_DIRECTION } = props;\n const { root } = useContext(context);\n const [dir, setDir] = useState(defaultDir);\n useEffect(() => {\n if (!root || typeof document === \"undefined\") {\n return;\n }\n\n document.documentElement.setAttribute(\"dir\", dir);\n\n return () => {\n document.documentElement.removeAttribute(\"dir\");\n };\n }, [dir, root]);\n\n const toggleDir = useCallback(() => {\n setDir((prevDir) => (prevDir === \"ltr\" ? \"rtl\" : \"ltr\"));\n }, []);\n\n const value = useMemo<InheritableContext>(\n () => ({ root: false, dir, toggleDir }),\n [dir, toggleDir]\n );\n let child = Children.only(children);\n if (!root) {\n child = cloneElement(child, { dir });\n }\n\n return <Provider value={value}>{child}</Provider>;\n}\n"],"names":["Children","cloneElement","createContext","useCallback","useContext","useEffect","useMemo","useState","context","root","dir","toggleDir","process","env","NODE_ENV","Error","displayName","Provider","useDir","_root","current","DEFAULT_WRITING_DIRECTION","document","rootDir","documentElement","getAttribute","WritingDirectionProvider","props","children","defaultDir","setDir","setAttribute","removeAttribute","prevDir","value","child","only"],"mappings":"AAAA;;AACA,SACEA,QAAQ,EACRC,YAAY,EACZC,aAAa,EACbC,WAAW,EACXC,UAAU,EACVC,SAAS,EACTC,OAAO,EACPC,QAAQ,QAEH,QAAQ;AA+Bf,MAAMC,wBAAUN,cAAkC;IAChDO,MAAM;IACNC,KAAK;IACLC,WAAW;QACT,IAAIC,QAAQC,GAAG,CAACC,QAAQ,KAAK,cAAc;YACzC,MAAM,IAAIC,MACR;QAEJ;IACF;AACF;AACAP,QAAQQ,WAAW,GAAG;AACtB,MAAM,EAAEC,QAAQ,EAAE,GAAGT;AAErB;;;;;;;;;;;;;;;;;;;;;;CAsBC,GACD,OAAO,SAASU;IACd,MAAM,EAAET,MAAMU,KAAK,EAAE,GAAGC,SAAS,GAAGhB,WAAWI;IAC/C,OAAOY;AACT;AAsBA;;;;;;;CAOC,GACD,OAAO,MAAMC,4BAA4B;IACvC,IAAIX,MAAW;IACf,IAAI,OAAOY,aAAa,aAAa;QACnC,MAAMC,UAAUD,SAASE,eAAe,CAACC,YAAY,CAAC;QACtDf,MAAMa,YAAY,QAAQ,QAAQ;IACpC;IAEA,OAAOb;AACT,EAAE;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4EC,GACD,OAAO,SAASgB,yBACdC,KAAoC;IAEpC,MAAM,EAAEC,QAAQ,EAAEC,aAAaR,yBAAyB,EAAE,GAAGM;IAC7D,MAAM,EAAElB,IAAI,EAAE,GAAGL,WAAWI;IAC5B,MAAM,CAACE,KAAKoB,OAAO,GAAGvB,SAASsB;IAC/BxB,UAAU;QACR,IAAI,CAACI,QAAQ,OAAOa,aAAa,aAAa;YAC5C;QACF;QAEAA,SAASE,eAAe,CAACO,YAAY,CAAC,OAAOrB;QAE7C,OAAO;YACLY,SAASE,eAAe,CAACQ,eAAe,CAAC;QAC3C;IACF,GAAG;QAACtB;QAAKD;KAAK;IAEd,MAAME,YAAYR,YAAY;QAC5B2B,OAAO,CAACG,UAAaA,YAAY,QAAQ,QAAQ;IACnD,GAAG,EAAE;IAEL,MAAMC,QAAQ5B,QACZ,IAAO,CAAA;YAAEG,MAAM;YAAOC;YAAKC;QAAU,CAAA,GACrC;QAACD;QAAKC;KAAU;IAElB,IAAIwB,QAAQnC,SAASoC,IAAI,CAACR;IAC1B,IAAI,CAACnB,MAAM;QACT0B,sBAAQlC,aAAakC,OAAO;YAAEzB;QAAI;IACpC;IAEA,qBAAO,KAACO;QAASiB,OAAOA;kBAAQC;;AAClC"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useAsyncAction.ts"],"sourcesContent":["\"use client\";\nimport { useCallback, useState } from \"react\";\nimport type { NonNullRef, UseStateSetter } from \"./types.js\";\nimport { useUnmounted } from \"./useUnmounted.js\";\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport type AsyncActionFunction<Args extends unknown[]> = (\n ...args: Args\n) => Promise<void>;\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport type HandleAsyncAction = <Args extends unknown[]>(\n action: AsyncActionFunction<Args>\n) => AsyncActionFunction<Args>;\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface AsyncActionOptions {\n /** @defaultValue `false` */\n disabled?: boolean;\n}\n\n/**\n * @remarks \\@since 6.0.0\n */\nexport interface AsyncActionImplementation {\n pending: boolean;\n unmounted: NonNullRef<boolean>;\n setPending: UseStateSetter<boolean>;\n handleAsync: HandleAsyncAction;\n}\n\n/**\n * A simple utility hook for triggering a pending state while an async function\n * is running. This is really only useful if you aren't using something like\n * `react-query`, `@reduxjs/toolkit/query`, `@apollo/client`, etc for API calls\n * which have a built-in pending state for mutations.\n *\n * @example\n * Simple Example (Async Button)\n * ```tsx\n * import type { ButtonProps } from \"@react-md/core\";\n * import { box, Button, CircularProgress, useAsyncAction } from \"@react-md/core\";\n * import { cnb } from \"cnbuilder\";\n * import type { MouseEvent, ReactElement } from \"react\";\n *\n * import styles from \"./AsyncButton.module.scss\";\n *\n * export interface AsyncButtonProps extends ButtonProps {\n * onClick(event: MouseEvent<HTMLButtonElement>): Promise<void>;\n * }\n *\n * export function AsyncButton(props: AsyncButtonProps): ReactElement {\n * const { onClick, children, theme, className, disabled, ...remaining } = props;\n * const { handleAsync, pending } = useAsyncAction({ disabled });\n *\n * return (\n * <Button\n * {...remaining}\n * aria-disabled={pending || undefined}\n * disabled={disabled}\n * className={cnb(pending && styles.loading, className)}\n * theme={pending ? \"disabled\" : theme}\n * onClick={handleAsync(onClick)}\n * >\n * {children}\n * {pending && (\n * <span\n * className={box({\n * align: \"center\",\n * disablePadding: true,\n * className: styles.overlay,\n * })}\n * >\n * <CircularProgress />\n * </span>\n * )}\n * </Button>\n * );\n * }\n *\n * // `AsyncButton.module.scss`\n * // hide everything in the button except for the overlay containing the circular\n * // progress\n * .loading > *:not(.overlay) {\n * opacity: 0;\n * }\n *\n * .overlay {\n * border-radius: inherit;\n * box-shadow: inherit;\n * inset: 0;\n * position: absolute;\n * z-index: 1;\n * }\n * ```\n *\n * @example\n * Confirmation Dialog with Overlay\n * ```tsx\n * import {\n * Button,\n * DialogHeader,\n * DialogContent,\n * DialogFooter,\n * Form,\n * useAsyncAction,\n * } from \"@react-md/core\";\n * import CloseIcon from \"@react-md/material-icons/CloseIcon\";\n * import type { ReactElement } from \"react\";\n * import { useId } from \"react\";\n *\n * interface ExampleProps {\n * hide(); void;\n * submit(): Promise<void>\n * }\n *\n * function Example({ hide, submit }: ExampleProps): ReactElement {\n * const { handleAsync, pending } = useAsyncAction();\n * const formId = useId();\n *\n * return (\n * <>\n * <DialogHeader>\n * <DialogTitle>Some Title</DialogTitle>\n * <Button aria-label=\"Close\" onClick={hide} disabled={pending}>\n * <CloseIcon />\n * </Button>\n * </DialogHeader>\n * <DialogContent>\n * <Form\n * id={formId}\n * onReset={hide}\n * onSubmit={handleAsync(submit)}\n * >\n * // pretend content\n * </Form>\n * </DialogContent>\n * <DialogFooter>\n * <Button\n * type=\"reset\"\n * form={formId}\n * disabled={pending}\n * >\n * Cancel\n * </Button>\n * <Button\n * type=\"submit\"\n * form={formId}\n * disabled={pending}\n * >\n * Confirm\n * </Button>\n * </DialogFooter>\n * </>\n * );\n * }\n * ```\n *\n * @remarks \\@since 6.0.0\n */\nexport function useAsyncAction(\n options: AsyncActionOptions = {}\n): AsyncActionImplementation {\n const { disabled } = options;\n\n const [pending, setPending] = useState(false);\n const unmounted = useUnmounted();\n\n const handleAsync = useCallback<HandleAsyncAction>(\n (action) =>\n async (...args) => {\n if (pending || disabled) {\n return;\n }\n\n setPending(true);\n try {\n await action(...args);\n } finally {\n if (!unmounted.current) {\n setPending(false);\n }\n }\n },\n [disabled, pending, unmounted]\n );\n\n return {\n pending,\n unmounted,\n setPending,\n handleAsync,\n };\n}\n"],"names":["useCallback","useState","useUnmounted","useAsyncAction","options","disabled","pending","setPending","unmounted","handleAsync","action","args","current"],"mappings":"AAAA;AACA,SAASA,WAAW,EAAEC,QAAQ,QAAQ,QAAQ;AAE9C,SAASC,YAAY,QAAQ,oBAAoB;AAkCjD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAgIC,GACD,OAAO,SAASC,eACdC,UAA8B,CAAC,CAAC;IAEhC,MAAM,EAAEC,QAAQ,EAAE,GAAGD;IAErB,MAAM,CAACE,SAASC,WAAW,GAAGN,SAAS;IACvC,MAAMO,YAAYN;IAElB,MAAMO,cAAcT,YAClB,CAACU,SACC,OAAO,GAAGC;YACR,IAAIL,WAAWD,UAAU;gBACvB;YACF;YAEAE,WAAW;YACX,IAAI;gBACF,MAAMG,UAAUC;YAClB,SAAU;gBACR,IAAI,CAACH,UAAUI,OAAO,EAAE;oBACtBL,WAAW;gBACb;YACF;QACF,GACF;QAACF;QAAUC;QAASE;KAAU;IAGhC,OAAO;QACLF;QACAE;QACAD;QACAE;IACF;AACF"}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/useDebouncedFunction.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 DebouncedFunction<F extends AnyFunction> = (\n ...args: Parameters<F>\n) => void;\n\n/**\n * Creates a function that will only be called if it has not been called again\n * for X milliseconds.\n *\n * @example\n * Debounced Search API Requests\n * ```tsx\n * import { TextField, useDebouncedFunction, 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 = useDebouncedFunction(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 `useThrottledFunction` for throttle behavior instead. (Call a\n * function at most once every X milliseconds).\n * @remarks \\@since 6.0.0\n */\nexport function useDebouncedFunction<F extends AnyFunction>(\n func: F,\n wait: number\n): DebouncedFunction<F> {\n const timeout = useRef<number | undefined>();\n const funcRef = useRef(func);\n useIsomorphicLayoutEffect(() => {\n funcRef.current = func;\n });\n\n useEffect(() => {\n return () => {\n window.clearTimeout(timeout.current);\n };\n }, []);\n\n return useCallback(\n (...args) => {\n window.clearTimeout(timeout.current);\n timeout.current = window.setTimeout(() => {\n funcRef.current(...args);\n }, wait);\n },\n [wait]\n );\n}\n"],"names":["useCallback","useEffect","useRef","useIsomorphicLayoutEffect","useDebouncedFunction","func","wait","timeout","funcRef","current","window","clearTimeout","args","setTimeout"],"mappings":"AAAA;AACA,SAASA,WAAW,EAAEC,SAAS,EAAEC,MAAM,QAAQ,QAAQ;AAEvD,SAASC,yBAAyB,QAAQ,iCAAiC;AAS3E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4EC,GACD,OAAO,SAASC,qBACdC,IAAO,EACPC,IAAY;IAEZ,MAAMC,UAAUL;IAChB,MAAMM,UAAUN,OAAOG;IACvBF,0BAA0B;QACxBK,QAAQC,OAAO,GAAGJ;IACpB;IAEAJ,UAAU;QACR,OAAO;YACLS,OAAOC,YAAY,CAACJ,QAAQE,OAAO;QACrC;IACF,GAAG,EAAE;IAEL,OAAOT,YACL,CAAC,GAAGY;QACFF,OAAOC,YAAY,CAACJ,QAAQE,OAAO;QACnCF,QAAQE,OAAO,GAAGC,OAAOG,UAAU,CAAC;YAClCL,QAAQC,OAAO,IAAIG;QACrB,GAAGN;IACL,GACA;QAACA;KAAK;AAEV"}