@react-md/core 6.0.1 → 6.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (763) hide show
  1. package/dist/CoreProviders.d.ts +1 -1
  2. package/dist/CoreProviders.js +1 -1
  3. package/dist/CoreProviders.js.map +1 -1
  4. package/dist/SsrProvider.d.ts +1 -1
  5. package/dist/SsrProvider.js +1 -1
  6. package/dist/SsrProvider.js.map +1 -1
  7. package/dist/autocomplete/Autocomplete.d.ts +2 -2
  8. package/dist/autocomplete/Autocomplete.js +1 -1
  9. package/dist/autocomplete/Autocomplete.js.map +1 -1
  10. package/dist/autocomplete/AutocompleteChip.d.ts +1 -1
  11. package/dist/autocomplete/AutocompleteChip.js +1 -1
  12. package/dist/autocomplete/AutocompleteChip.js.map +1 -1
  13. package/dist/autocomplete/AutocompleteCircularProgress.d.ts +1 -1
  14. package/dist/autocomplete/AutocompleteCircularProgress.js +1 -1
  15. package/dist/autocomplete/AutocompleteCircularProgress.js.map +1 -1
  16. package/dist/autocomplete/AutocompleteClearButton.d.ts +1 -1
  17. package/dist/autocomplete/AutocompleteClearButton.js +1 -1
  18. package/dist/autocomplete/AutocompleteClearButton.js.map +1 -1
  19. package/dist/autocomplete/AutocompleteDropdownButton.d.ts +1 -1
  20. package/dist/autocomplete/AutocompleteDropdownButton.js +1 -1
  21. package/dist/autocomplete/AutocompleteDropdownButton.js.map +1 -1
  22. package/dist/autocomplete/_autocomplete.scss +8 -5
  23. package/dist/autocomplete/useAutocomplete.d.ts +3 -3
  24. package/dist/autocomplete/useAutocomplete.js +2 -1
  25. package/dist/autocomplete/useAutocomplete.js.map +1 -1
  26. package/dist/avatar/Avatar.d.ts +1 -1
  27. package/dist/avatar/Avatar.js +1 -1
  28. package/dist/avatar/Avatar.js.map +1 -1
  29. package/dist/badge/Badge.d.ts +1 -1
  30. package/dist/badge/Badge.js +1 -1
  31. package/dist/badge/Badge.js.map +1 -1
  32. package/dist/box/Box.d.ts +1 -1
  33. package/dist/box/Box.js +1 -1
  34. package/dist/box/Box.js.map +1 -1
  35. package/dist/button/AsyncButton.d.ts +1 -1
  36. package/dist/button/AsyncButton.js +1 -1
  37. package/dist/button/AsyncButton.js.map +1 -1
  38. package/dist/button/Button.d.ts +1 -1
  39. package/dist/button/Button.js +1 -1
  40. package/dist/button/Button.js.map +1 -1
  41. package/dist/button/ButtonUnstyled.d.ts +1 -1
  42. package/dist/button/ButtonUnstyled.js +1 -1
  43. package/dist/button/ButtonUnstyled.js.map +1 -1
  44. package/dist/button/TooltippedButton.d.ts +1 -1
  45. package/dist/button/TooltippedButton.js +1 -1
  46. package/dist/button/TooltippedButton.js.map +1 -1
  47. package/dist/card/Card.d.ts +1 -1
  48. package/dist/card/Card.js +1 -1
  49. package/dist/card/Card.js.map +1 -1
  50. package/dist/card/CardContent.d.ts +1 -1
  51. package/dist/card/CardContent.js +1 -1
  52. package/dist/card/CardContent.js.map +1 -1
  53. package/dist/card/CardFooter.d.ts +1 -1
  54. package/dist/card/CardFooter.js +1 -1
  55. package/dist/card/CardFooter.js.map +1 -1
  56. package/dist/card/CardHeader.d.ts +1 -1
  57. package/dist/card/CardHeader.js +1 -1
  58. package/dist/card/CardHeader.js.map +1 -1
  59. package/dist/card/CardSubtitle.d.ts +1 -1
  60. package/dist/card/CardSubtitle.js +1 -1
  61. package/dist/card/CardSubtitle.js.map +1 -1
  62. package/dist/card/CardTitle.d.ts +1 -1
  63. package/dist/card/CardTitle.js +1 -1
  64. package/dist/card/CardTitle.js.map +1 -1
  65. package/dist/card/ClickableCard.d.ts +1 -1
  66. package/dist/card/ClickableCard.js +1 -1
  67. package/dist/card/ClickableCard.js.map +1 -1
  68. package/dist/chip/Chip.d.ts +1 -1
  69. package/dist/chip/Chip.js +1 -1
  70. package/dist/chip/Chip.js.map +1 -1
  71. package/dist/dialog/Dialog.d.ts +1 -1
  72. package/dist/dialog/Dialog.js +1 -1
  73. package/dist/dialog/Dialog.js.map +1 -1
  74. package/dist/dialog/DialogContent.d.ts +1 -1
  75. package/dist/dialog/DialogContent.js +1 -1
  76. package/dist/dialog/DialogContent.js.map +1 -1
  77. package/dist/dialog/DialogFooter.d.ts +1 -1
  78. package/dist/dialog/DialogFooter.js +1 -1
  79. package/dist/dialog/DialogFooter.js.map +1 -1
  80. package/dist/dialog/DialogHeader.d.ts +1 -1
  81. package/dist/dialog/DialogHeader.js +1 -1
  82. package/dist/dialog/DialogHeader.js.map +1 -1
  83. package/dist/dialog/DialogTitle.d.ts +1 -1
  84. package/dist/dialog/DialogTitle.js +1 -1
  85. package/dist/dialog/DialogTitle.js.map +1 -1
  86. package/dist/dialog/FixedDialog.d.ts +1 -1
  87. package/dist/dialog/FixedDialog.js +1 -1
  88. package/dist/dialog/FixedDialog.js.map +1 -1
  89. package/dist/divider/Divider.d.ts +1 -1
  90. package/dist/divider/Divider.js +1 -1
  91. package/dist/divider/Divider.js.map +1 -1
  92. package/dist/draggable/useDraggable.d.ts +1 -1
  93. package/dist/draggable/useDraggable.js +1 -1
  94. package/dist/draggable/useDraggable.js.map +1 -1
  95. package/dist/expansion-panel/ExpansionList.d.ts +1 -1
  96. package/dist/expansion-panel/ExpansionList.js +1 -1
  97. package/dist/expansion-panel/ExpansionList.js.map +1 -1
  98. package/dist/expansion-panel/ExpansionPanel.d.ts +1 -1
  99. package/dist/expansion-panel/ExpansionPanel.js +1 -1
  100. package/dist/expansion-panel/ExpansionPanel.js.map +1 -1
  101. package/dist/expansion-panel/ExpansionPanelHeader.d.ts +1 -1
  102. package/dist/expansion-panel/ExpansionPanelHeader.js +1 -1
  103. package/dist/expansion-panel/ExpansionPanelHeader.js.map +1 -1
  104. package/dist/expansion-panel/useExpansionList.d.ts +1 -1
  105. package/dist/expansion-panel/useExpansionList.js +1 -1
  106. package/dist/expansion-panel/useExpansionList.js.map +1 -1
  107. package/dist/expansion-panel/useExpansionPanels.d.ts +1 -1
  108. package/dist/expansion-panel/useExpansionPanels.js +1 -1
  109. package/dist/expansion-panel/useExpansionPanels.js.map +1 -1
  110. package/dist/files/FileInput.d.ts +1 -1
  111. package/dist/files/FileInput.js +1 -1
  112. package/dist/files/FileInput.js.map +1 -1
  113. package/dist/files/useFileUpload.d.ts +2 -2
  114. package/dist/files/useFileUpload.js +2 -2
  115. package/dist/files/useFileUpload.js.map +1 -1
  116. package/dist/form/Checkbox.d.ts +1 -1
  117. package/dist/form/Checkbox.js +1 -1
  118. package/dist/form/Checkbox.js.map +1 -1
  119. package/dist/form/Fieldset.d.ts +1 -1
  120. package/dist/form/Fieldset.js +1 -1
  121. package/dist/form/Fieldset.js.map +1 -1
  122. package/dist/form/Form.d.ts +1 -1
  123. package/dist/form/Form.js +1 -1
  124. package/dist/form/Form.js.map +1 -1
  125. package/dist/form/FormMessage.d.ts +1 -1
  126. package/dist/form/FormMessage.js +1 -1
  127. package/dist/form/FormMessage.js.map +1 -1
  128. package/dist/form/FormMessageContainer.d.ts +1 -1
  129. package/dist/form/FormMessageContainer.js +1 -1
  130. package/dist/form/FormMessageContainer.js.map +1 -1
  131. package/dist/form/FormMessageCounter.d.ts +2 -2
  132. package/dist/form/FormMessageCounter.js +2 -2
  133. package/dist/form/FormMessageCounter.js.map +1 -1
  134. package/dist/form/InputToggle.d.ts +2 -2
  135. package/dist/form/InputToggle.js +2 -2
  136. package/dist/form/InputToggle.js.map +1 -1
  137. package/dist/form/Label.d.ts +3 -3
  138. package/dist/form/Label.js +3 -3
  139. package/dist/form/Label.js.map +1 -1
  140. package/dist/form/Legend.d.ts +1 -1
  141. package/dist/form/Legend.js +1 -1
  142. package/dist/form/Legend.js.map +1 -1
  143. package/dist/form/NativeSelect.d.ts +1 -1
  144. package/dist/form/NativeSelect.js +1 -1
  145. package/dist/form/NativeSelect.js.map +1 -1
  146. package/dist/form/OptGroup.d.ts +1 -1
  147. package/dist/form/OptGroup.js +1 -1
  148. package/dist/form/OptGroup.js.map +1 -1
  149. package/dist/form/Option.d.ts +1 -1
  150. package/dist/form/Option.js +1 -1
  151. package/dist/form/Option.js.map +1 -1
  152. package/dist/form/Password.d.ts +1 -1
  153. package/dist/form/Password.js +1 -1
  154. package/dist/form/Password.js.map +1 -1
  155. package/dist/form/Radio.d.ts +1 -1
  156. package/dist/form/Radio.js +1 -1
  157. package/dist/form/Radio.js.map +1 -1
  158. package/dist/form/Select.d.ts +1 -1
  159. package/dist/form/Select.js +1 -1
  160. package/dist/form/Select.js.map +1 -1
  161. package/dist/form/Slider.d.ts +1 -1
  162. package/dist/form/Slider.js.map +1 -1
  163. package/dist/form/Switch.d.ts +1 -1
  164. package/dist/form/Switch.js +1 -1
  165. package/dist/form/Switch.js.map +1 -1
  166. package/dist/form/TextArea.d.ts +1 -1
  167. package/dist/form/TextArea.js +1 -1
  168. package/dist/form/TextArea.js.map +1 -1
  169. package/dist/form/TextField.d.ts +1 -1
  170. package/dist/form/TextField.js +1 -1
  171. package/dist/form/TextField.js.map +1 -1
  172. package/dist/form/useCheckboxGroup.d.ts +8 -8
  173. package/dist/form/useCheckboxGroup.js +2 -2
  174. package/dist/form/useCheckboxGroup.js.map +1 -1
  175. package/dist/form/useCombobox.js +1 -0
  176. package/dist/form/useCombobox.js.map +1 -1
  177. package/dist/form/useNumberField.d.ts +2 -2
  178. package/dist/form/useNumberField.js +2 -2
  179. package/dist/form/useNumberField.js.map +1 -1
  180. package/dist/form/useRadioGroup.d.ts +4 -4
  181. package/dist/form/useRadioGroup.js +2 -2
  182. package/dist/form/useRadioGroup.js.map +1 -1
  183. package/dist/form/useRangeSlider.d.ts +1 -1
  184. package/dist/form/useRangeSlider.js +1 -1
  185. package/dist/form/useRangeSlider.js.map +1 -1
  186. package/dist/form/useSlider.d.ts +1 -1
  187. package/dist/form/useSlider.js +1 -1
  188. package/dist/form/useSlider.js.map +1 -1
  189. package/dist/form/useTextField.d.ts +4 -4
  190. package/dist/form/useTextField.js +2 -2
  191. package/dist/form/useTextField.js.map +1 -1
  192. package/dist/icon/FontIcon.d.ts +1 -1
  193. package/dist/icon/FontIcon.js +1 -1
  194. package/dist/icon/FontIcon.js.map +1 -1
  195. package/dist/icon/IconRotator.d.ts +1 -1
  196. package/dist/icon/IconRotator.js +1 -1
  197. package/dist/icon/IconRotator.js.map +1 -1
  198. package/dist/icon/MaterialIcon.d.ts +2 -2
  199. package/dist/icon/MaterialIcon.js +2 -2
  200. package/dist/icon/MaterialIcon.js.map +1 -1
  201. package/dist/icon/MaterialSymbol.d.ts +2 -2
  202. package/dist/icon/MaterialSymbol.js +2 -2
  203. package/dist/icon/MaterialSymbol.js.map +1 -1
  204. package/dist/icon/SVGIcon.d.ts +1 -1
  205. package/dist/icon/SVGIcon.js +1 -1
  206. package/dist/icon/SVGIcon.js.map +1 -1
  207. package/dist/icon/TextIconSpacing.d.ts +1 -1
  208. package/dist/icon/TextIconSpacing.js +1 -1
  209. package/dist/icon/TextIconSpacing.js.map +1 -1
  210. package/dist/layout/LayoutAppBar.d.ts +1 -1
  211. package/dist/layout/LayoutAppBar.js +1 -1
  212. package/dist/layout/LayoutAppBar.js.map +1 -1
  213. package/dist/layout/LayoutNav.d.ts +1 -1
  214. package/dist/layout/LayoutNav.js +1 -1
  215. package/dist/layout/LayoutNav.js.map +1 -1
  216. package/dist/layout/LayoutWindowSplitter.d.ts +1 -1
  217. package/dist/layout/LayoutWindowSplitter.js +1 -1
  218. package/dist/layout/LayoutWindowSplitter.js.map +1 -1
  219. package/dist/layout/Main.d.ts +1 -1
  220. package/dist/layout/Main.js +1 -1
  221. package/dist/layout/Main.js.map +1 -1
  222. package/dist/layout/useExpandableLayout.d.ts +1 -1
  223. package/dist/layout/useExpandableLayout.js +1 -1
  224. package/dist/layout/useExpandableLayout.js.map +1 -1
  225. package/dist/layout/useHorizontalLayoutTransition.d.ts +1 -1
  226. package/dist/layout/useHorizontalLayoutTransition.js +1 -1
  227. package/dist/layout/useHorizontalLayoutTransition.js.map +1 -1
  228. package/dist/layout/useLayoutAppBarHeight.d.ts +1 -1
  229. package/dist/layout/useLayoutAppBarHeight.js +1 -1
  230. package/dist/layout/useLayoutAppBarHeight.js.map +1 -1
  231. package/dist/layout/useLayoutTree.d.ts +3 -3
  232. package/dist/layout/useLayoutTree.js +3 -3
  233. package/dist/layout/useLayoutTree.js.map +1 -1
  234. package/dist/layout/useLayoutWindowSplitter.d.ts +1 -1
  235. package/dist/layout/useLayoutWindowSplitter.js +1 -1
  236. package/dist/layout/useLayoutWindowSplitter.js.map +1 -1
  237. package/dist/layout/useResizableLayout.d.ts +1 -1
  238. package/dist/layout/useResizableLayout.js +1 -1
  239. package/dist/layout/useResizableLayout.js.map +1 -1
  240. package/dist/layout/useTemporaryLayout.d.ts +1 -1
  241. package/dist/layout/useTemporaryLayout.js +1 -1
  242. package/dist/layout/useTemporaryLayout.js.map +1 -1
  243. package/dist/link/Link.d.ts +1 -1
  244. package/dist/link/Link.js +1 -1
  245. package/dist/link/Link.js.map +1 -1
  246. package/dist/link/SkipToMainContent.d.ts +1 -1
  247. package/dist/link/SkipToMainContent.js +1 -1
  248. package/dist/link/SkipToMainContent.js.map +1 -1
  249. package/dist/list/List.d.ts +1 -1
  250. package/dist/list/List.js +1 -1
  251. package/dist/list/List.js.map +1 -1
  252. package/dist/list/ListItem.d.ts +1 -1
  253. package/dist/list/ListItem.js +1 -1
  254. package/dist/list/ListItem.js.map +1 -1
  255. package/dist/list/ListItemChildren.d.ts +1 -1
  256. package/dist/list/ListItemChildren.js +1 -1
  257. package/dist/list/ListItemChildren.js.map +1 -1
  258. package/dist/list/ListItemLink.d.ts +1 -1
  259. package/dist/list/ListItemLink.js +1 -1
  260. package/dist/list/ListItemLink.js.map +1 -1
  261. package/dist/list/ListSubheader.d.ts +1 -1
  262. package/dist/list/ListSubheader.js +1 -1
  263. package/dist/list/ListSubheader.js.map +1 -1
  264. package/dist/media-queries/AppSizeProvider.d.ts +2 -2
  265. package/dist/media-queries/AppSizeProvider.js +2 -2
  266. package/dist/media-queries/AppSizeProvider.js.map +1 -1
  267. package/dist/media-queries/useMediaQuery.d.ts +2 -2
  268. package/dist/media-queries/useMediaQuery.js +2 -2
  269. package/dist/media-queries/useMediaQuery.js.map +1 -1
  270. package/dist/menu/DropdownMenu.d.ts +1 -1
  271. package/dist/menu/DropdownMenu.js +2 -1
  272. package/dist/menu/DropdownMenu.js.map +1 -1
  273. package/dist/menu/Menu.d.ts +1 -1
  274. package/dist/menu/Menu.js +1 -1
  275. package/dist/menu/Menu.js.map +1 -1
  276. package/dist/menu/MenuBar.d.ts +1 -1
  277. package/dist/menu/MenuBar.js +1 -1
  278. package/dist/menu/MenuBar.js.map +1 -1
  279. package/dist/menu/MenuButton.d.ts +1 -1
  280. package/dist/menu/MenuButton.js +1 -1
  281. package/dist/menu/MenuButton.js.map +1 -1
  282. package/dist/menu/MenuItem.d.ts +1 -1
  283. package/dist/menu/MenuItem.js +1 -1
  284. package/dist/menu/MenuItem.js.map +1 -1
  285. package/dist/menu/MenuItemCheckbox.d.ts +1 -1
  286. package/dist/menu/MenuItemCheckbox.js +1 -1
  287. package/dist/menu/MenuItemCheckbox.js.map +1 -1
  288. package/dist/menu/MenuItemFileInput.d.ts +1 -1
  289. package/dist/menu/MenuItemFileInput.js +1 -1
  290. package/dist/menu/MenuItemFileInput.js.map +1 -1
  291. package/dist/menu/MenuItemGroup.d.ts +1 -1
  292. package/dist/menu/MenuItemGroup.js +1 -1
  293. package/dist/menu/MenuItemGroup.js.map +1 -1
  294. package/dist/menu/MenuItemInputToggle.d.ts +1 -1
  295. package/dist/menu/MenuItemInputToggle.js +1 -1
  296. package/dist/menu/MenuItemInputToggle.js.map +1 -1
  297. package/dist/menu/MenuItemRadio.d.ts +1 -1
  298. package/dist/menu/MenuItemRadio.js +1 -1
  299. package/dist/menu/MenuItemRadio.js.map +1 -1
  300. package/dist/menu/MenuItemSeparator.d.ts +1 -1
  301. package/dist/menu/MenuItemSeparator.js +1 -1
  302. package/dist/menu/MenuItemSeparator.js.map +1 -1
  303. package/dist/menu/MenuItemSwitch.d.ts +1 -1
  304. package/dist/menu/MenuItemSwitch.js +1 -1
  305. package/dist/menu/MenuItemSwitch.js.map +1 -1
  306. package/dist/menu/MenuItemTextField.d.ts +1 -1
  307. package/dist/menu/MenuItemTextField.js +1 -1
  308. package/dist/menu/MenuItemTextField.js.map +1 -1
  309. package/dist/menu/useContextMenu.d.ts +1 -1
  310. package/dist/menu/useContextMenu.js +1 -1
  311. package/dist/menu/useContextMenu.js.map +1 -1
  312. package/dist/navigation/CollapsibleNavGroup.d.ts +1 -1
  313. package/dist/navigation/CollapsibleNavGroup.js +1 -1
  314. package/dist/navigation/CollapsibleNavGroup.js.map +1 -1
  315. package/dist/navigation/DefaultNavigationRenderer.d.ts +1 -1
  316. package/dist/navigation/DefaultNavigationRenderer.js +1 -1
  317. package/dist/navigation/DefaultNavigationRenderer.js.map +1 -1
  318. package/dist/navigation/NavGroup.d.ts +1 -1
  319. package/dist/navigation/NavGroup.js +1 -1
  320. package/dist/navigation/NavGroup.js.map +1 -1
  321. package/dist/navigation/NavItem.d.ts +1 -1
  322. package/dist/navigation/NavItem.js +1 -1
  323. package/dist/navigation/NavItem.js.map +1 -1
  324. package/dist/navigation/NavItemButton.d.ts +1 -1
  325. package/dist/navigation/NavItemButton.js +1 -1
  326. package/dist/navigation/NavItemButton.js.map +1 -1
  327. package/dist/navigation/NavItemLink.d.ts +1 -1
  328. package/dist/navigation/NavItemLink.js +1 -1
  329. package/dist/navigation/NavItemLink.js.map +1 -1
  330. package/dist/navigation/NavSubheader.d.ts +1 -1
  331. package/dist/navigation/NavSubheader.js +1 -1
  332. package/dist/navigation/NavSubheader.js.map +1 -1
  333. package/dist/navigation/Navigation.d.ts +1 -1
  334. package/dist/navigation/Navigation.js +1 -1
  335. package/dist/navigation/Navigation.js.map +1 -1
  336. package/dist/navigation/useActiveHeadingId.d.ts +1 -1
  337. package/dist/navigation/useActiveHeadingId.js +1 -1
  338. package/dist/navigation/useActiveHeadingId.js.map +1 -1
  339. package/dist/navigation/useNavigationExpansion.d.ts +2 -2
  340. package/dist/navigation/useNavigationExpansion.js +2 -2
  341. package/dist/navigation/useNavigationExpansion.js.map +1 -1
  342. package/dist/navigation/useTableOfContentsHeadings.d.ts +1 -1
  343. package/dist/navigation/useTableOfContentsHeadings.js +1 -1
  344. package/dist/navigation/useTableOfContentsHeadings.js.map +1 -1
  345. package/dist/overlay/Overlay.d.ts +1 -1
  346. package/dist/overlay/Overlay.js +1 -1
  347. package/dist/overlay/Overlay.js.map +1 -1
  348. package/dist/portal/Portal.d.ts +1 -1
  349. package/dist/portal/Portal.js +1 -1
  350. package/dist/portal/Portal.js.map +1 -1
  351. package/dist/portal/PortalContainerProvider.d.ts +1 -1
  352. package/dist/portal/PortalContainerProvider.js +1 -1
  353. package/dist/portal/PortalContainerProvider.js.map +1 -1
  354. package/dist/positioning/useFixedPositioning.d.ts +1 -1
  355. package/dist/positioning/useFixedPositioning.js +1 -1
  356. package/dist/positioning/useFixedPositioning.js.map +1 -1
  357. package/dist/progress/CircularProgress.d.ts +1 -1
  358. package/dist/progress/CircularProgress.js +1 -1
  359. package/dist/progress/CircularProgress.js.map +1 -1
  360. package/dist/progress/LinearProgress.d.ts +1 -1
  361. package/dist/progress/LinearProgress.js +1 -1
  362. package/dist/progress/LinearProgress.js.map +1 -1
  363. package/dist/responsive-item/ResponsiveItem.d.ts +1 -1
  364. package/dist/responsive-item/ResponsiveItem.js +1 -1
  365. package/dist/responsive-item/ResponsiveItem.js.map +1 -1
  366. package/dist/responsive-item/ResponsiveItemOverlay.d.ts +1 -1
  367. package/dist/responsive-item/ResponsiveItemOverlay.js +1 -1
  368. package/dist/responsive-item/ResponsiveItemOverlay.js.map +1 -1
  369. package/dist/scroll/useScrollLock.d.ts +1 -1
  370. package/dist/scroll/useScrollLock.js +1 -1
  371. package/dist/scroll/useScrollLock.js.map +1 -1
  372. package/dist/segmented-button/SegmentedButton.d.ts +1 -1
  373. package/dist/segmented-button/SegmentedButton.js +1 -1
  374. package/dist/segmented-button/SegmentedButton.js.map +1 -1
  375. package/dist/segmented-button/SegmentedButtonContainer.d.ts +1 -1
  376. package/dist/segmented-button/SegmentedButtonContainer.js +1 -1
  377. package/dist/segmented-button/SegmentedButtonContainer.js.map +1 -1
  378. package/dist/sheet/Sheet.d.ts +1 -1
  379. package/dist/sheet/Sheet.js +1 -1
  380. package/dist/sheet/Sheet.js.map +1 -1
  381. package/dist/snackbar/DefaultToastRenderer.d.ts +1 -1
  382. package/dist/snackbar/DefaultToastRenderer.js +1 -1
  383. package/dist/snackbar/DefaultToastRenderer.js.map +1 -1
  384. package/dist/snackbar/Snackbar.d.ts +1 -1
  385. package/dist/snackbar/Snackbar.js +1 -1
  386. package/dist/snackbar/Snackbar.js.map +1 -1
  387. package/dist/snackbar/Toast.d.ts +1 -1
  388. package/dist/snackbar/Toast.js +1 -1
  389. package/dist/snackbar/Toast.js.map +1 -1
  390. package/dist/snackbar/ToastActionButton.d.ts +1 -1
  391. package/dist/snackbar/ToastActionButton.js +1 -1
  392. package/dist/snackbar/ToastActionButton.js.map +1 -1
  393. package/dist/snackbar/ToastCloseButton.d.ts +1 -1
  394. package/dist/snackbar/ToastCloseButton.js +1 -1
  395. package/dist/snackbar/ToastCloseButton.js.map +1 -1
  396. package/dist/snackbar/ToastContent.d.ts +1 -1
  397. package/dist/snackbar/ToastContent.js +1 -1
  398. package/dist/snackbar/ToastContent.js.map +1 -1
  399. package/dist/snackbar/ToastManager.d.ts +1 -1
  400. package/dist/snackbar/ToastManager.js +1 -1
  401. package/dist/snackbar/ToastManager.js.map +1 -1
  402. package/dist/snackbar/ToastManagerProvider.d.ts +1 -1
  403. package/dist/snackbar/ToastManagerProvider.js +1 -1
  404. package/dist/snackbar/ToastManagerProvider.js.map +1 -1
  405. package/dist/snackbar/useCurrentToastActions.d.ts +1 -1
  406. package/dist/snackbar/useCurrentToastActions.js +1 -1
  407. package/dist/snackbar/useCurrentToastActions.js.map +1 -1
  408. package/dist/storage/useStorage.d.ts +1 -1
  409. package/dist/storage/useStorage.js +1 -1
  410. package/dist/storage/useStorage.js.map +1 -1
  411. package/dist/suspense/CircularProgressSuspense.d.ts +1 -1
  412. package/dist/suspense/CircularProgressSuspense.js +1 -1
  413. package/dist/suspense/CircularProgressSuspense.js.map +1 -1
  414. package/dist/suspense/NullSuspense.d.ts +1 -1
  415. package/dist/suspense/NullSuspense.js +1 -1
  416. package/dist/suspense/NullSuspense.js.map +1 -1
  417. package/dist/table/StickyTableSection.d.ts +2 -2
  418. package/dist/table/StickyTableSection.js +2 -2
  419. package/dist/table/StickyTableSection.js.map +1 -1
  420. package/dist/table/Table.d.ts +1 -1
  421. package/dist/table/Table.js +1 -1
  422. package/dist/table/Table.js.map +1 -1
  423. package/dist/table/TableBody.d.ts +1 -1
  424. package/dist/table/TableBody.js +1 -1
  425. package/dist/table/TableBody.js.map +1 -1
  426. package/dist/table/TableCell.d.ts +1 -1
  427. package/dist/table/TableCell.js +1 -1
  428. package/dist/table/TableCell.js.map +1 -1
  429. package/dist/table/TableCheckbox.d.ts +1 -1
  430. package/dist/table/TableCheckbox.js +1 -1
  431. package/dist/table/TableCheckbox.js.map +1 -1
  432. package/dist/table/TableContainer.d.ts +1 -1
  433. package/dist/table/TableContainer.js +1 -1
  434. package/dist/table/TableContainer.js.map +1 -1
  435. package/dist/table/TableFooter.d.ts +1 -1
  436. package/dist/table/TableFooter.js +1 -1
  437. package/dist/table/TableFooter.js.map +1 -1
  438. package/dist/table/TableHeader.d.ts +1 -1
  439. package/dist/table/TableHeader.js +1 -1
  440. package/dist/table/TableHeader.js.map +1 -1
  441. package/dist/table/TableRadio.d.ts +1 -1
  442. package/dist/table/TableRadio.js +1 -1
  443. package/dist/table/TableRadio.js.map +1 -1
  444. package/dist/table/TableRow.d.ts +1 -1
  445. package/dist/table/TableRow.js +1 -1
  446. package/dist/table/TableRow.js.map +1 -1
  447. package/dist/tabs/SimpleTabPanel.d.ts +2 -2
  448. package/dist/tabs/SimpleTabPanel.js +2 -2
  449. package/dist/tabs/SimpleTabPanel.js.map +1 -1
  450. package/dist/tabs/SimpleTabPanels.d.ts +2 -2
  451. package/dist/tabs/SimpleTabPanels.js +2 -2
  452. package/dist/tabs/SimpleTabPanels.js.map +1 -1
  453. package/dist/tabs/Tab.d.ts +1 -1
  454. package/dist/tabs/Tab.js +1 -1
  455. package/dist/tabs/Tab.js.map +1 -1
  456. package/dist/tabs/TabList.d.ts +1 -1
  457. package/dist/tabs/TabList.js +1 -1
  458. package/dist/tabs/TabList.js.map +1 -1
  459. package/dist/tabs/useTabs.d.ts +4 -4
  460. package/dist/tabs/useTabs.js +2 -1
  461. package/dist/tabs/useTabs.js.map +1 -1
  462. package/dist/theme/LocalStorageColorSchemeProvider.d.ts +2 -2
  463. package/dist/theme/LocalStorageColorSchemeProvider.js +2 -2
  464. package/dist/theme/LocalStorageColorSchemeProvider.js.map +1 -1
  465. package/dist/theme/ThemeProvider.d.ts +1 -1
  466. package/dist/theme/ThemeProvider.js +1 -1
  467. package/dist/theme/ThemeProvider.js.map +1 -1
  468. package/dist/theme/useColorSchemeProvider.js +1 -0
  469. package/dist/theme/useColorSchemeProvider.js.map +1 -1
  470. package/dist/tooltip/Tooltip.d.ts +1 -1
  471. package/dist/tooltip/Tooltip.js +1 -1
  472. package/dist/tooltip/Tooltip.js.map +1 -1
  473. package/dist/tooltip/TooltipHoverModeProvider.d.ts +1 -1
  474. package/dist/tooltip/TooltipHoverModeProvider.js +1 -1
  475. package/dist/tooltip/TooltipHoverModeProvider.js.map +1 -1
  476. package/dist/tooltip/useTooltip.d.ts +1 -1
  477. package/dist/tooltip/useTooltip.js +1 -1
  478. package/dist/tooltip/useTooltip.js.map +1 -1
  479. package/dist/transition/CSSTransition.d.ts +1 -1
  480. package/dist/transition/CSSTransition.js +1 -1
  481. package/dist/transition/CSSTransition.js.map +1 -1
  482. package/dist/transition/Collapse.d.ts +1 -1
  483. package/dist/transition/Collapse.js +1 -1
  484. package/dist/transition/Collapse.js.map +1 -1
  485. package/dist/transition/CrossFade.d.ts +1 -1
  486. package/dist/transition/CrossFade.js +1 -1
  487. package/dist/transition/CrossFade.js.map +1 -1
  488. package/dist/transition/ScaleTransition.d.ts +1 -1
  489. package/dist/transition/ScaleTransition.js +1 -1
  490. package/dist/transition/ScaleTransition.js.map +1 -1
  491. package/dist/transition/SkeletonPlaceholder.d.ts +1 -1
  492. package/dist/transition/SkeletonPlaceholder.js +1 -1
  493. package/dist/transition/SkeletonPlaceholder.js.map +1 -1
  494. package/dist/transition/Slide.d.ts +1 -1
  495. package/dist/transition/Slide.js +1 -1
  496. package/dist/transition/Slide.js.map +1 -1
  497. package/dist/transition/SlideContainer.d.ts +1 -1
  498. package/dist/transition/SlideContainer.js +1 -1
  499. package/dist/transition/SlideContainer.js.map +1 -1
  500. package/dist/transition/useCSSTransition.d.ts +2 -2
  501. package/dist/transition/useCSSTransition.js +2 -2
  502. package/dist/transition/useCSSTransition.js.map +1 -1
  503. package/dist/transition/useCarousel.d.ts +1 -1
  504. package/dist/transition/useCarousel.js +1 -1
  505. package/dist/transition/useCarousel.js.map +1 -1
  506. package/dist/transition/useCollapseTransition.d.ts +2 -2
  507. package/dist/transition/useCollapseTransition.js +2 -2
  508. package/dist/transition/useCollapseTransition.js.map +1 -1
  509. package/dist/transition/useCrossFadeTransition.d.ts +2 -2
  510. package/dist/transition/useCrossFadeTransition.js +2 -2
  511. package/dist/transition/useCrossFadeTransition.js.map +1 -1
  512. package/dist/transition/useScaleTransition.d.ts +2 -2
  513. package/dist/transition/useScaleTransition.js +2 -2
  514. package/dist/transition/useScaleTransition.js.map +1 -1
  515. package/dist/transition/useSkeletonPlaceholder.d.ts +2 -2
  516. package/dist/transition/useSkeletonPlaceholder.js +2 -2
  517. package/dist/transition/useSkeletonPlaceholder.js.map +1 -1
  518. package/dist/transition/useSlideTransition.d.ts +1 -1
  519. package/dist/transition/useSlideTransition.js +1 -1
  520. package/dist/transition/useSlideTransition.js.map +1 -1
  521. package/dist/transition/useTransition.d.ts +1 -1
  522. package/dist/transition/useTransition.js +1 -1
  523. package/dist/transition/useTransition.js.map +1 -1
  524. package/dist/tree/DefaultTreeItemRenderer.d.ts +1 -1
  525. package/dist/tree/DefaultTreeItemRenderer.js +1 -1
  526. package/dist/tree/DefaultTreeItemRenderer.js.map +1 -1
  527. package/dist/tree/Tree.d.ts +1 -1
  528. package/dist/tree/Tree.js +1 -1
  529. package/dist/tree/Tree.js.map +1 -1
  530. package/dist/tree/TreeItem.d.ts +1 -1
  531. package/dist/tree/TreeItem.js +1 -1
  532. package/dist/tree/TreeItem.js.map +1 -1
  533. package/dist/tree/useTree.d.ts +1 -1
  534. package/dist/tree/useTree.js +1 -1
  535. package/dist/tree/useTree.js.map +1 -1
  536. package/dist/tree/useTreeExpansion.d.ts +1 -1
  537. package/dist/tree/useTreeExpansion.js +1 -1
  538. package/dist/tree/useTreeExpansion.js.map +1 -1
  539. package/dist/tree/useTreeItems.d.ts +1 -1
  540. package/dist/tree/useTreeItems.js +1 -1
  541. package/dist/tree/useTreeItems.js.map +1 -1
  542. package/dist/tree/useTreeSelection.d.ts +1 -1
  543. package/dist/tree/useTreeSelection.js +1 -1
  544. package/dist/tree/useTreeSelection.js.map +1 -1
  545. package/dist/typography/HighlightText.d.ts +1 -1
  546. package/dist/typography/HighlightText.js +1 -1
  547. package/dist/typography/HighlightText.js.map +1 -1
  548. package/dist/typography/Mark.d.ts +1 -1
  549. package/dist/typography/Mark.js +1 -1
  550. package/dist/typography/Mark.js.map +1 -1
  551. package/dist/typography/SrOnly.d.ts +1 -1
  552. package/dist/typography/SrOnly.js +1 -1
  553. package/dist/typography/SrOnly.js.map +1 -1
  554. package/dist/typography/TextContainer.d.ts +1 -1
  555. package/dist/typography/TextContainer.js +1 -1
  556. package/dist/typography/TextContainer.js.map +1 -1
  557. package/dist/typography/Typography.d.ts +1 -1
  558. package/dist/typography/Typography.js +1 -1
  559. package/dist/typography/Typography.js.map +1 -1
  560. package/dist/typography/WritingDirectionProvider.d.ts +1 -1
  561. package/dist/typography/WritingDirectionProvider.js +1 -1
  562. package/dist/typography/WritingDirectionProvider.js.map +1 -1
  563. package/dist/useEnsuredState.d.ts +1 -0
  564. package/dist/useEnsuredState.js +5 -3
  565. package/dist/useEnsuredState.js.map +1 -1
  566. package/dist/utils/RenderRecursively.d.ts +1 -1
  567. package/dist/utils/RenderRecursively.js +1 -1
  568. package/dist/utils/RenderRecursively.js.map +1 -1
  569. package/dist/window-splitter/WindowSplitter.d.ts +1 -1
  570. package/dist/window-splitter/WindowSplitter.js +1 -1
  571. package/dist/window-splitter/WindowSplitter.js.map +1 -1
  572. package/package.json +1 -1
  573. package/src/CoreProviders.tsx +1 -1
  574. package/src/SsrProvider.tsx +1 -1
  575. package/src/autocomplete/Autocomplete.tsx +3 -3
  576. package/src/autocomplete/AutocompleteChip.tsx +1 -1
  577. package/src/autocomplete/AutocompleteCircularProgress.tsx +1 -1
  578. package/src/autocomplete/AutocompleteClearButton.tsx +1 -1
  579. package/src/autocomplete/AutocompleteDropdownButton.tsx +1 -1
  580. package/src/autocomplete/useAutocomplete.ts +5 -4
  581. package/src/avatar/Avatar.tsx +1 -1
  582. package/src/badge/Badge.tsx +1 -1
  583. package/src/box/Box.tsx +1 -1
  584. package/src/button/AsyncButton.tsx +1 -1
  585. package/src/button/Button.tsx +1 -1
  586. package/src/button/ButtonUnstyled.tsx +1 -1
  587. package/src/button/TooltippedButton.tsx +1 -1
  588. package/src/card/Card.tsx +1 -1
  589. package/src/card/CardContent.tsx +1 -1
  590. package/src/card/CardFooter.tsx +1 -1
  591. package/src/card/CardHeader.tsx +1 -1
  592. package/src/card/CardSubtitle.tsx +1 -1
  593. package/src/card/CardTitle.tsx +1 -1
  594. package/src/card/ClickableCard.tsx +1 -1
  595. package/src/chip/Chip.tsx +1 -1
  596. package/src/dialog/Dialog.tsx +1 -1
  597. package/src/dialog/DialogContent.tsx +1 -1
  598. package/src/dialog/DialogFooter.tsx +1 -1
  599. package/src/dialog/DialogHeader.tsx +1 -1
  600. package/src/dialog/DialogTitle.tsx +1 -1
  601. package/src/dialog/FixedDialog.tsx +1 -1
  602. package/src/divider/Divider.tsx +1 -1
  603. package/src/draggable/useDraggable.ts +1 -1
  604. package/src/expansion-panel/ExpansionList.tsx +1 -1
  605. package/src/expansion-panel/ExpansionPanel.tsx +1 -1
  606. package/src/expansion-panel/ExpansionPanelHeader.tsx +1 -1
  607. package/src/expansion-panel/useExpansionList.ts +1 -1
  608. package/src/expansion-panel/useExpansionPanels.ts +1 -1
  609. package/src/files/FileInput.tsx +1 -1
  610. package/src/files/useFileUpload.ts +2 -2
  611. package/src/form/Checkbox.tsx +1 -1
  612. package/src/form/Fieldset.tsx +1 -1
  613. package/src/form/Form.tsx +1 -1
  614. package/src/form/FormMessage.tsx +1 -1
  615. package/src/form/FormMessageContainer.tsx +1 -1
  616. package/src/form/FormMessageCounter.tsx +2 -2
  617. package/src/form/InputToggle.tsx +2 -2
  618. package/src/form/Label.tsx +3 -3
  619. package/src/form/Legend.tsx +1 -1
  620. package/src/form/NativeSelect.tsx +1 -1
  621. package/src/form/OptGroup.tsx +1 -1
  622. package/src/form/Option.tsx +1 -1
  623. package/src/form/Password.tsx +1 -1
  624. package/src/form/Radio.tsx +1 -1
  625. package/src/form/Select.tsx +1 -1
  626. package/src/form/Slider.tsx +1 -1
  627. package/src/form/Switch.tsx +1 -1
  628. package/src/form/TextArea.tsx +1 -1
  629. package/src/form/TextField.tsx +1 -1
  630. package/src/form/useCheckboxGroup.ts +10 -10
  631. package/src/form/useCombobox.ts +1 -0
  632. package/src/form/useNumberField.ts +4 -4
  633. package/src/form/useRadioGroup.ts +6 -6
  634. package/src/form/useRangeSlider.ts +1 -1
  635. package/src/form/useSlider.ts +1 -1
  636. package/src/form/useTextField.ts +6 -6
  637. package/src/icon/FontIcon.tsx +1 -1
  638. package/src/icon/IconRotator.tsx +1 -1
  639. package/src/icon/MaterialIcon.tsx +2 -2
  640. package/src/icon/MaterialSymbol.tsx +2 -2
  641. package/src/icon/SVGIcon.tsx +1 -1
  642. package/src/icon/TextIconSpacing.tsx +1 -1
  643. package/src/layout/LayoutAppBar.tsx +1 -1
  644. package/src/layout/LayoutNav.tsx +1 -1
  645. package/src/layout/LayoutWindowSplitter.tsx +1 -1
  646. package/src/layout/Main.tsx +1 -1
  647. package/src/layout/useExpandableLayout.ts +1 -1
  648. package/src/layout/useHorizontalLayoutTransition.ts +1 -1
  649. package/src/layout/useLayoutAppBarHeight.ts +1 -1
  650. package/src/layout/useLayoutTree.ts +3 -3
  651. package/src/layout/useLayoutWindowSplitter.ts +1 -1
  652. package/src/layout/useResizableLayout.ts +1 -1
  653. package/src/layout/useTemporaryLayout.ts +1 -1
  654. package/src/link/Link.tsx +1 -1
  655. package/src/link/SkipToMainContent.tsx +1 -1
  656. package/src/list/List.tsx +1 -1
  657. package/src/list/ListItem.tsx +1 -1
  658. package/src/list/ListItemChildren.tsx +1 -1
  659. package/src/list/ListItemLink.tsx +1 -1
  660. package/src/list/ListSubheader.tsx +1 -1
  661. package/src/media-queries/AppSizeProvider.tsx +2 -2
  662. package/src/media-queries/useMediaQuery.ts +2 -2
  663. package/src/menu/DropdownMenu.tsx +2 -1
  664. package/src/menu/Menu.tsx +1 -1
  665. package/src/menu/MenuBar.tsx +1 -1
  666. package/src/menu/MenuButton.tsx +1 -1
  667. package/src/menu/MenuItem.tsx +1 -1
  668. package/src/menu/MenuItemCheckbox.tsx +1 -1
  669. package/src/menu/MenuItemFileInput.tsx +1 -1
  670. package/src/menu/MenuItemGroup.tsx +1 -1
  671. package/src/menu/MenuItemInputToggle.tsx +1 -1
  672. package/src/menu/MenuItemRadio.tsx +1 -1
  673. package/src/menu/MenuItemSeparator.tsx +1 -1
  674. package/src/menu/MenuItemSwitch.tsx +1 -1
  675. package/src/menu/MenuItemTextField.tsx +1 -1
  676. package/src/menu/useContextMenu.ts +1 -1
  677. package/src/navigation/CollapsibleNavGroup.tsx +1 -1
  678. package/src/navigation/DefaultNavigationRenderer.tsx +1 -1
  679. package/src/navigation/NavGroup.tsx +1 -1
  680. package/src/navigation/NavItem.tsx +1 -1
  681. package/src/navigation/NavItemButton.tsx +1 -1
  682. package/src/navigation/NavItemLink.tsx +1 -1
  683. package/src/navigation/NavSubheader.tsx +1 -1
  684. package/src/navigation/Navigation.tsx +1 -1
  685. package/src/navigation/useActiveHeadingId.ts +1 -1
  686. package/src/navigation/useNavigationExpansion.ts +2 -2
  687. package/src/navigation/useTableOfContentsHeadings.ts +1 -1
  688. package/src/overlay/Overlay.tsx +1 -1
  689. package/src/portal/Portal.tsx +1 -1
  690. package/src/portal/PortalContainerProvider.tsx +1 -1
  691. package/src/positioning/useFixedPositioning.ts +1 -1
  692. package/src/progress/CircularProgress.tsx +1 -1
  693. package/src/progress/LinearProgress.tsx +1 -1
  694. package/src/responsive-item/ResponsiveItem.tsx +1 -1
  695. package/src/responsive-item/ResponsiveItemOverlay.tsx +1 -1
  696. package/src/scroll/useScrollLock.ts +1 -1
  697. package/src/segmented-button/SegmentedButton.tsx +1 -1
  698. package/src/segmented-button/SegmentedButtonContainer.tsx +1 -1
  699. package/src/sheet/Sheet.tsx +1 -1
  700. package/src/snackbar/DefaultToastRenderer.tsx +1 -1
  701. package/src/snackbar/Snackbar.tsx +1 -1
  702. package/src/snackbar/Toast.tsx +1 -1
  703. package/src/snackbar/ToastActionButton.tsx +1 -1
  704. package/src/snackbar/ToastCloseButton.tsx +1 -1
  705. package/src/snackbar/ToastContent.tsx +1 -1
  706. package/src/snackbar/ToastManager.ts +1 -1
  707. package/src/snackbar/ToastManagerProvider.tsx +1 -1
  708. package/src/snackbar/useCurrentToastActions.ts +1 -1
  709. package/src/storage/useStorage.ts +1 -1
  710. package/src/suspense/CircularProgressSuspense.tsx +1 -1
  711. package/src/suspense/NullSuspense.tsx +1 -1
  712. package/src/table/StickyTableSection.tsx +2 -2
  713. package/src/table/Table.tsx +1 -1
  714. package/src/table/TableBody.tsx +1 -1
  715. package/src/table/TableCell.tsx +1 -1
  716. package/src/table/TableCheckbox.tsx +1 -1
  717. package/src/table/TableContainer.tsx +1 -1
  718. package/src/table/TableFooter.tsx +1 -1
  719. package/src/table/TableHeader.tsx +1 -1
  720. package/src/table/TableRadio.tsx +1 -1
  721. package/src/table/TableRow.tsx +1 -1
  722. package/src/tabs/SimpleTabPanel.tsx +2 -2
  723. package/src/tabs/SimpleTabPanels.tsx +2 -2
  724. package/src/tabs/Tab.tsx +1 -1
  725. package/src/tabs/TabList.tsx +1 -1
  726. package/src/tabs/useTabs.ts +6 -5
  727. package/src/theme/LocalStorageColorSchemeProvider.tsx +2 -2
  728. package/src/theme/ThemeProvider.tsx +1 -1
  729. package/src/theme/useColorSchemeProvider.ts +1 -0
  730. package/src/tooltip/Tooltip.tsx +1 -1
  731. package/src/tooltip/TooltipHoverModeProvider.tsx +1 -1
  732. package/src/tooltip/useTooltip.ts +1 -1
  733. package/src/transition/CSSTransition.tsx +1 -1
  734. package/src/transition/Collapse.tsx +1 -1
  735. package/src/transition/CrossFade.tsx +1 -1
  736. package/src/transition/ScaleTransition.tsx +1 -1
  737. package/src/transition/SkeletonPlaceholder.tsx +1 -1
  738. package/src/transition/Slide.tsx +1 -1
  739. package/src/transition/SlideContainer.tsx +1 -1
  740. package/src/transition/useCSSTransition.ts +2 -2
  741. package/src/transition/useCarousel.ts +1 -1
  742. package/src/transition/useCollapseTransition.ts +2 -2
  743. package/src/transition/useCrossFadeTransition.ts +2 -2
  744. package/src/transition/useScaleTransition.ts +2 -2
  745. package/src/transition/useSkeletonPlaceholder.ts +2 -2
  746. package/src/transition/useSlideTransition.ts +1 -1
  747. package/src/transition/useTransition.ts +1 -1
  748. package/src/tree/DefaultTreeItemRenderer.tsx +1 -1
  749. package/src/tree/Tree.tsx +1 -1
  750. package/src/tree/TreeItem.tsx +1 -1
  751. package/src/tree/useTree.ts +1 -1
  752. package/src/tree/useTreeExpansion.ts +1 -1
  753. package/src/tree/useTreeItems.ts +1 -1
  754. package/src/tree/useTreeSelection.ts +1 -1
  755. package/src/typography/HighlightText.tsx +1 -1
  756. package/src/typography/Mark.tsx +1 -1
  757. package/src/typography/SrOnly.tsx +1 -1
  758. package/src/typography/TextContainer.tsx +1 -1
  759. package/src/typography/Typography.tsx +1 -1
  760. package/src/typography/WritingDirectionProvider.tsx +1 -1
  761. package/src/useEnsuredState.ts +6 -3
  762. package/src/utils/RenderRecursively.tsx +1 -1
  763. package/src/window-splitter/WindowSplitter.tsx +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/tree/Tree.tsx"],"sourcesContent":["\"use client\";\n\nimport {\n type ComponentType,\n type HTMLAttributes,\n type ReactElement,\n type ReactNode,\n type Ref,\n} from \"react\";\n\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 { RenderRecursively } from \"../utils/RenderRecursively.js\";\nimport { identity } from \"../utils/identity.js\";\nimport { DefaultTreeItemRenderer } from \"./DefaultTreeItemRenderer.js\";\nimport { type TreeExpansionMode, TreeProvider } from \"./TreeProvider.js\";\nimport { tree } from \"./styles.js\";\nimport {\n type TreeData,\n type TreeItemNode,\n type TreeItemRendererProps,\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 * @since 6.0.0\n */\nexport type TreeHTMLAttributes = Omit<\n HTMLAttributes<HTMLUListElement>,\n \"role\" | \"tabIndex\" | \"children\"\n>;\n\n/**\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 * @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 Custom Tree Item Renderer\n * ```tsx\n * import { useTreeContext } from \"@react-md/core/movement/TreeProvider\"\n * import { useKeyboardMovementContext } from \"@react-md/core/movement/useKeyboardMovementProvider\"\n * import { TreeItem } from \"@react-md/core/tree/TreeItem\";\n * import { type TreeItemRendererProps } from \"@react-md/core/tree/types\";\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<TreeItemRendererProps<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 Simple Tree\n * ```tsx\n * import { Tree } from \"@react-md/core/tree/Tree\";\n * import { type TreeData } from \"@react-md/core/tree/types\";\n * import { useTree } from \"@react-md/core/tree/useTree\";\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 https://next.react-md.dev/components/tree | Tree Demos}\n * @see {@link TreeProps.renderer} for a custom tree item example.\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 render={TreeItemRenderer}\n getItemKey={(options) => options.item.itemId}\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","render","getItemKey","options","item","itemId"],"mappings":"AAAA;;AAWA,SAASA,IAAI,QAAQ,kBAAkB;AACvC,SAASC,wBAAwB,QAAQ,6CAA6C;AAEtF,SAASC,YAAY,QAAQ,qBAAqB;AAClD,SAASC,iBAAiB,QAAQ,gCAAgC;AAClE,SAASC,QAAQ,QAAQ,uBAAuB;AAChD,SAASC,uBAAuB,QAAQ,+BAA+B;AACvE,SAAiCC,YAAY,QAAQ,oBAAoB;AACzE,SAASC,IAAI,QAAQ,cAAc;AAQnC,SAASC,YAAY,QAAQ,oBAAoB;AACjD,SAASC,eAAe,QAAQ,uBAAuB;AAoJvD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA0DC,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,QAAQnB;oBACRoB,YAAY,CAACC,UAAYA,QAAQC,IAAI,CAACC,MAAM;;;;;AAMxD"}
1
+ {"version":3,"sources":["../../src/tree/Tree.tsx"],"sourcesContent":["\"use client\";\n\nimport {\n type ComponentType,\n type HTMLAttributes,\n type ReactElement,\n type ReactNode,\n type Ref,\n} from \"react\";\n\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 { RenderRecursively } from \"../utils/RenderRecursively.js\";\nimport { identity } from \"../utils/identity.js\";\nimport { DefaultTreeItemRenderer } from \"./DefaultTreeItemRenderer.js\";\nimport { type TreeExpansionMode, TreeProvider } from \"./TreeProvider.js\";\nimport { tree } from \"./styles.js\";\nimport {\n type TreeData,\n type TreeItemNode,\n type TreeItemRendererProps,\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 * @since 6.0.0\n */\nexport type TreeHTMLAttributes = Omit<\n HTMLAttributes<HTMLUListElement>,\n \"role\" | \"tabIndex\" | \"children\"\n>;\n\n/**\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 * @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 Custom Tree Item Renderer\n * ```tsx\n * import { useTreeContext } from \"@react-md/core/movement/TreeProvider\"\n * import { useKeyboardMovementContext } from \"@react-md/core/movement/useKeyboardMovementProvider\"\n * import { TreeItem } from \"@react-md/core/tree/TreeItem\";\n * import { type TreeItemRendererProps } from \"@react-md/core/tree/types\";\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<TreeItemRendererProps<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 Simple Tree\n * ```tsx\n * import { Tree } from \"@react-md/core/tree/Tree\";\n * import { type TreeData } from \"@react-md/core/tree/types\";\n * import { useTree } from \"@react-md/core/tree/useTree\";\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 https://react-md.dev/components/tree | Tree Demos}\n * @see {@link TreeProps.renderer} for a custom tree item example.\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 render={TreeItemRenderer}\n getItemKey={(options) => options.item.itemId}\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","render","getItemKey","options","item","itemId"],"mappings":"AAAA;;AAWA,SAASA,IAAI,QAAQ,kBAAkB;AACvC,SAASC,wBAAwB,QAAQ,6CAA6C;AAEtF,SAASC,YAAY,QAAQ,qBAAqB;AAClD,SAASC,iBAAiB,QAAQ,gCAAgC;AAClE,SAASC,QAAQ,QAAQ,uBAAuB;AAChD,SAASC,uBAAuB,QAAQ,+BAA+B;AACvE,SAAiCC,YAAY,QAAQ,oBAAoB;AACzE,SAASC,IAAI,QAAQ,cAAc;AAQnC,SAASC,YAAY,QAAQ,oBAAoB;AACjD,SAASC,eAAe,QAAQ,uBAAuB;AAoJvD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA0DC,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,QAAQnB;oBACRoB,YAAY,CAACC,UAAYA,QAAQC,IAAI,CAACC,MAAM;;;;;AAMxD"}
@@ -57,7 +57,7 @@ export interface TreeItemProps extends Omit<DefaultTreeItemNode, "parentId">, HT
57
57
  /**
58
58
  * **Client Component**
59
59
  *
60
- * @see {@link https://next.react-md.dev/components/tree | Tree Demos}
60
+ * @see {@link https://react-md.dev/components/tree | Tree Demos}
61
61
  * @see {@link https://www.w3.org/WAI/ARIA/apg/patterns/treeview/}
62
62
  * @since 6.0.0 No longer forwards refs. The ref must be provided using
63
63
  * `contentRef` instead.
@@ -13,7 +13,7 @@ import { treeItem, treeItemContent, treeItemMedia } from "./styles.js";
13
13
  /**
14
14
  * **Client Component**
15
15
  *
16
- * @see {@link https://next.react-md.dev/components/tree | Tree Demos}
16
+ * @see {@link https://react-md.dev/components/tree | Tree Demos}
17
17
  * @see {@link https://www.w3.org/WAI/ARIA/apg/patterns/treeview/}
18
18
  * @since 6.0.0 No longer forwards refs. The ref must be provided using
19
19
  * `contentRef` instead.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/tree/TreeItem.tsx"],"sourcesContent":["\"use client\";\n\nimport {\n type HTMLAttributes,\n type ReactElement,\n type ReactNode,\n type Ref,\n useEffect,\n} from \"react\";\n\nimport { type ComponentWithRippleProps } from \"../interaction/types.js\";\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 { type OverridableTreeGroupProps, TreeGroup } 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 * @since 6.0.0 Added `liProps` and `groupProps`.\n * @since 6.0.0 The `liRef`, `liStyle`, and `liClassName` props were removed in\n * favor of `liProps={{ ref, style, className }}`.\n * @since 6.0.0 The `itemIndex`, `listSize`, `renderChildItems`, `isLink`,\n * `contentComponent`, and `readOnly` props were removed.\n */\nexport interface TreeItemProps\n extends Omit<DefaultTreeItemNode, \"parentId\">,\n HTMLAttributes<HTMLLIElement>,\n ComponentWithRippleProps {\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://next.react-md.dev/components/tree | Tree Demos}\n * @see {@link https://www.w3.org/WAI/ARIA/apg/patterns/treeview/}\n * @since 6.0.0 No longer forwards refs. The ref must be provided using\n * `contentRef` instead.\n * @since 6.0.0 The `liRef` was removed in favor of `liProps={{ ref }}`.\n * @since 6.0.0 The wrapping `<li>` element will always be `role=\"none\"` and the\n * `<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 disableRipple,\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 /* eslint-disable @typescript-eslint/no-dynamic-delete */\n delete lookup.disabledItems[itemId];\n delete lookup.expandable[itemId];\n delete lookup.elementToItem[id];\n delete lookup.itemToElement[itemId];\n /* eslint-enable @typescript-eslint/no-dynamic-delete */\n };\n }, [id, metadataLookup, itemId, isLeafNode, disabled, depth]);\n\n const { pressedClassName, ripples, handlers } =\n useElementInteraction<HTMLLIElement>({\n mode: disableRipple ? \"none\" : undefined,\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","disableRipple","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","mode","event","isLink","ContentComponent","isMediaLeftAddon","li","role","expander","aria-expanded","aria-selected","aria-disabled","ref","tabIndex","link","isLeft","addon","temporary","collapsed"],"mappings":"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"}
1
+ {"version":3,"sources":["../../src/tree/TreeItem.tsx"],"sourcesContent":["\"use client\";\n\nimport {\n type HTMLAttributes,\n type ReactElement,\n type ReactNode,\n type Ref,\n useEffect,\n} from \"react\";\n\nimport { type ComponentWithRippleProps } from \"../interaction/types.js\";\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 { type OverridableTreeGroupProps, TreeGroup } 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 * @since 6.0.0 Added `liProps` and `groupProps`.\n * @since 6.0.0 The `liRef`, `liStyle`, and `liClassName` props were removed in\n * favor of `liProps={{ ref, style, className }}`.\n * @since 6.0.0 The `itemIndex`, `listSize`, `renderChildItems`, `isLink`,\n * `contentComponent`, and `readOnly` props were removed.\n */\nexport interface TreeItemProps\n extends Omit<DefaultTreeItemNode, \"parentId\">,\n HTMLAttributes<HTMLLIElement>,\n ComponentWithRippleProps {\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://react-md.dev/components/tree | Tree Demos}\n * @see {@link https://www.w3.org/WAI/ARIA/apg/patterns/treeview/}\n * @since 6.0.0 No longer forwards refs. The ref must be provided using\n * `contentRef` instead.\n * @since 6.0.0 The `liRef` was removed in favor of `liProps={{ ref }}`.\n * @since 6.0.0 The wrapping `<li>` element will always be `role=\"none\"` and the\n * `<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 disableRipple,\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 /* eslint-disable @typescript-eslint/no-dynamic-delete */\n delete lookup.disabledItems[itemId];\n delete lookup.expandable[itemId];\n delete lookup.elementToItem[id];\n delete lookup.itemToElement[itemId];\n /* eslint-enable @typescript-eslint/no-dynamic-delete */\n };\n }, [id, metadataLookup, itemId, isLeafNode, disabled, depth]);\n\n const { pressedClassName, ripples, handlers } =\n useElementInteraction<HTMLLIElement>({\n mode: disableRipple ? \"none\" : undefined,\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","disableRipple","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","mode","event","isLink","ContentComponent","isMediaLeftAddon","li","role","expander","aria-expanded","aria-selected","aria-disabled","ref","tabIndex","link","isLeft","addon","temporary","collapsed"],"mappings":"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"}
@@ -45,7 +45,7 @@ export interface TreeImplementation extends TreeSelection, TreeExpansion {
45
45
  * }
46
46
  * ```
47
47
  *
48
- * @see {@link https://next.react-md.dev/components/tree | Tree Demos}
48
+ * @see {@link https://react-md.dev/components/tree | Tree Demos}
49
49
  * @since 6.0.0
50
50
  */
51
51
  export declare function useTree(options?: TreeHookOptions): TreeImplementation;
@@ -23,7 +23,7 @@ import { useTreeSelection } from "./useTreeSelection.js";
23
23
  * }
24
24
  * ```
25
25
  *
26
- * @see {@link https://next.react-md.dev/components/tree | Tree Demos}
26
+ * @see {@link https://react-md.dev/components/tree | Tree Demos}
27
27
  * @since 6.0.0
28
28
  */ export function useTree(options = {}) {
29
29
  const { multiSelect = false, defaultExpandedIds, defaultSelectedIds } = options;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/tree/useTree.ts"],"sourcesContent":["\"use client\";\n\nimport { type TreeDefaultIds } from \"./types.js\";\nimport { type TreeExpansion, useTreeExpansion } from \"./useTreeExpansion.js\";\nimport { type TreeSelection, useTreeSelection } from \"./useTreeSelection.js\";\n\n/**\n * @since 6.0.0\n */\nexport interface TreeHookOptions {\n /**\n * @defaultValue `false`\n */\n multiSelect?: boolean;\n\n /**\n * @defaultValue `[]`\n */\n defaultExpandedIds?: TreeDefaultIds;\n\n /**\n * @defaultValue `[]`\n */\n defaultSelectedIds?: TreeDefaultIds;\n}\n\n/**\n * @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 Simple Example\n * ```tsx\n * import { Tree } from \"@react-md/core/tree/Tree\";\n * import { type TreeData } from \"@react-md/core/tree/types\";\n * import { useTree } from \"@react-md/core/tree/useTree\";\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 * @see {@link https://next.react-md.dev/components/tree | Tree Demos}\n * @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,SAA6BA,gBAAgB,QAAQ,wBAAwB;AAC7E,SAA6BC,gBAAgB,QAAQ,wBAAwB;AA2B7E;;;;;;;;;;;;;;;;;;;;;;;;CAwBC,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"}
1
+ {"version":3,"sources":["../../src/tree/useTree.ts"],"sourcesContent":["\"use client\";\n\nimport { type TreeDefaultIds } from \"./types.js\";\nimport { type TreeExpansion, useTreeExpansion } from \"./useTreeExpansion.js\";\nimport { type TreeSelection, useTreeSelection } from \"./useTreeSelection.js\";\n\n/**\n * @since 6.0.0\n */\nexport interface TreeHookOptions {\n /**\n * @defaultValue `false`\n */\n multiSelect?: boolean;\n\n /**\n * @defaultValue `[]`\n */\n defaultExpandedIds?: TreeDefaultIds;\n\n /**\n * @defaultValue `[]`\n */\n defaultSelectedIds?: TreeDefaultIds;\n}\n\n/**\n * @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 Simple Example\n * ```tsx\n * import { Tree } from \"@react-md/core/tree/Tree\";\n * import { type TreeData } from \"@react-md/core/tree/types\";\n * import { useTree } from \"@react-md/core/tree/useTree\";\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 * @see {@link https://react-md.dev/components/tree | Tree Demos}\n * @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,SAA6BA,gBAAgB,QAAQ,wBAAwB;AAC7E,SAA6BC,gBAAgB,QAAQ,wBAAwB;AA2B7E;;;;;;;;;;;;;;;;;;;;;;;;CAwBC,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"}
@@ -12,7 +12,7 @@ export interface TreeExpansion {
12
12
  expandMultipleTreeItems: UseStateSetter<TreeItemIdSet>;
13
13
  }
14
14
  /**
15
- * @see {@link https://next.react-md.dev/components/tree | Tree Demos}
15
+ * @see {@link https://react-md.dev/components/tree | Tree Demos}
16
16
  * @since 6.0.0 Renamed from `useTreeItemExpansion` and uses a Set
17
17
  * instead of a list to increase performance.
18
18
  */
@@ -1,7 +1,7 @@
1
1
  "use client";
2
2
  import { useReadonlySet } from "../useReadonlySet.js";
3
3
  /**
4
- * @see {@link https://next.react-md.dev/components/tree | Tree Demos}
4
+ * @see {@link https://react-md.dev/components/tree | Tree Demos}
5
5
  * @since 6.0.0 Renamed from `useTreeItemExpansion` and uses a Set
6
6
  * instead of a list to increase performance.
7
7
  */ export function useTreeExpansion(defaultExpandedIds) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/tree/useTreeExpansion.ts"],"sourcesContent":["\"use client\";\n\nimport { type UseStateSetter } from \"../types.js\";\nimport { useReadonlySet } from \"../useReadonlySet.js\";\nimport { type TreeDefaultIds, type TreeItemIdSet } from \"./types.js\";\n\n/**\n * @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 * @see {@link https://next.react-md.dev/components/tree | Tree Demos}\n * @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?: TreeDefaultIds\n): TreeExpansion {\n const { value, setValue, toggleValue } = useReadonlySet({\n defaultValue: defaultExpandedIds,\n });\n\n return {\n expandedIds: value,\n toggleTreeItemExpansion: toggleValue,\n expandMultipleTreeItems: setValue,\n };\n}\n"],"names":["useReadonlySet","useTreeExpansion","defaultExpandedIds","value","setValue","toggleValue","defaultValue","expandedIds","toggleTreeItemExpansion","expandMultipleTreeItems"],"mappings":"AAAA;AAGA,SAASA,cAAc,QAAQ,uBAAuB;AAetD;;;;CAIC,GACD,OAAO,SAASC,iBACdC,kBAAmC;IAEnC,MAAM,EAAEC,KAAK,EAAEC,QAAQ,EAAEC,WAAW,EAAE,GAAGL,eAAe;QACtDM,cAAcJ;IAChB;IAEA,OAAO;QACLK,aAAaJ;QACbK,yBAAyBH;QACzBI,yBAAyBL;IAC3B;AACF"}
1
+ {"version":3,"sources":["../../src/tree/useTreeExpansion.ts"],"sourcesContent":["\"use client\";\n\nimport { type UseStateSetter } from \"../types.js\";\nimport { useReadonlySet } from \"../useReadonlySet.js\";\nimport { type TreeDefaultIds, type TreeItemIdSet } from \"./types.js\";\n\n/**\n * @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 * @see {@link https://react-md.dev/components/tree | Tree Demos}\n * @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?: TreeDefaultIds\n): TreeExpansion {\n const { value, setValue, toggleValue } = useReadonlySet({\n defaultValue: defaultExpandedIds,\n });\n\n return {\n expandedIds: value,\n toggleTreeItemExpansion: toggleValue,\n expandMultipleTreeItems: setValue,\n };\n}\n"],"names":["useReadonlySet","useTreeExpansion","defaultExpandedIds","value","setValue","toggleValue","defaultValue","expandedIds","toggleTreeItemExpansion","expandMultipleTreeItems"],"mappings":"AAAA;AAGA,SAASA,cAAc,QAAQ,uBAAuB;AAetD;;;;CAIC,GACD,OAAO,SAASC,iBACdC,kBAAmC;IAEnC,MAAM,EAAEC,KAAK,EAAEC,QAAQ,EAAEC,WAAW,EAAE,GAAGL,eAAe;QACtDM,cAAcJ;IAChB;IAEA,OAAO;QACLK,aAAaJ;QACbK,yBAAyBH;QACzBI,yBAAyBL;IAC3B;AACF"}
@@ -52,7 +52,7 @@ export interface TreeItems<T extends TreeItemNode> {
52
52
  * This is mostly an internal hook, but can be used to build tree-like
53
53
  * data structures without the need of the `Tree` component.
54
54
  *
55
- * @see {@link https://next.react-md.dev/components/tree | Tree Demos}
55
+ * @see {@link https://react-md.dev/components/tree | Tree Demos}
56
56
  * @since 6.0.0 converted to use an object argument instead of
57
57
  * multiple arguments. Also logs any orphaned items that do not have a parent
58
58
  */
@@ -44,7 +44,7 @@ import { useMemo } from "react";
44
44
  * This is mostly an internal hook, but can be used to build tree-like
45
45
  * data structures without the need of the `Tree` component.
46
46
  *
47
- * @see {@link https://next.react-md.dev/components/tree | Tree Demos}
47
+ * @see {@link https://react-md.dev/components/tree | Tree Demos}
48
48
  * @since 6.0.0 converted to use an object argument instead of
49
49
  * multiple arguments. Also logs any orphaned items that do not have a parent
50
50
  */ export function useTreeItems(options) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/tree/useTreeItems.ts"],"sourcesContent":["import { useMemo } from \"react\";\n\nimport type {\n DefaultTreeItemNode,\n TreeData,\n TreeItemNode,\n TreeItemSorter,\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 * @since 6.0.0\n * @internal\n */\nexport type TreeItemChildIds = Map<string | null, Set<string>>;\n\n/**\n * @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 * @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 * @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 * @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 * @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 * @see {@link https://next.react-md.dev/components/tree | Tree Demos}\n * @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;AAwChC;;;;;;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;;;;;;;CAOC,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"}
1
+ {"version":3,"sources":["../../src/tree/useTreeItems.ts"],"sourcesContent":["import { useMemo } from \"react\";\n\nimport type {\n DefaultTreeItemNode,\n TreeData,\n TreeItemNode,\n TreeItemSorter,\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 * @since 6.0.0\n * @internal\n */\nexport type TreeItemChildIds = Map<string | null, Set<string>>;\n\n/**\n * @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 * @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 * @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 * @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 * @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 * @see {@link https://react-md.dev/components/tree | Tree Demos}\n * @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;AAwChC;;;;;;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;;;;;;;CAOC,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"}
@@ -14,7 +14,7 @@ export interface TreeSelection {
14
14
  selectMultipleTreeItems: UseStateSetter<TreeItemIdSet>;
15
15
  }
16
16
  /**
17
- * @see {@link https://next.react-md.dev/components/tree | Tree Demos}
17
+ * @see {@link https://react-md.dev/components/tree | Tree Demos}
18
18
  * @since 6.0.0 Renamed from `useTreeItemSelection` and uses a Set
19
19
  * instead of a list to increase performance.
20
20
  */
@@ -1,7 +1,7 @@
1
1
  "use client";
2
2
  import { useReadonlySet } from "../useReadonlySet.js";
3
3
  /**
4
- * @see {@link https://next.react-md.dev/components/tree | Tree Demos}
4
+ * @see {@link https://react-md.dev/components/tree | Tree Demos}
5
5
  * @since 6.0.0 Renamed from `useTreeItemSelection` and uses a Set
6
6
  * instead of a list to increase performance.
7
7
  */ export function useTreeSelection(defaultSelectedIds, multiSelect = false) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/tree/useTreeSelection.ts"],"sourcesContent":["\"use client\";\n\nimport { type UseStateSetter } from \"../types.js\";\nimport { useReadonlySet } from \"../useReadonlySet.js\";\nimport { type TreeDefaultIds, type TreeItemIdSet } from \"./types.js\";\n\n/**\n * @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 * @see {@link https://next.react-md.dev/components/tree | Tree Demos}\n * @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?: TreeDefaultIds,\n multiSelect = false\n): Required<TreeSelection> {\n const { value, setValue, toggleValue } = useReadonlySet({\n toggleType: multiSelect ? \"multiple\" : \"single-select\",\n defaultValue: defaultSelectedIds,\n });\n\n return {\n multiSelect,\n selectedIds: value,\n toggleTreeItemSelection: toggleValue,\n selectMultipleTreeItems: setValue,\n };\n}\n"],"names":["useReadonlySet","useTreeSelection","defaultSelectedIds","multiSelect","value","setValue","toggleValue","toggleType","defaultValue","selectedIds","toggleTreeItemSelection","selectMultipleTreeItems"],"mappings":"AAAA;AAGA,SAASA,cAAc,QAAQ,uBAAuB;AAiBtD;;;;CAIC,GACD,OAAO,SAASC,iBACdC,kBAAmC,EACnCC,cAAc,KAAK;IAEnB,MAAM,EAAEC,KAAK,EAAEC,QAAQ,EAAEC,WAAW,EAAE,GAAGN,eAAe;QACtDO,YAAYJ,cAAc,aAAa;QACvCK,cAAcN;IAChB;IAEA,OAAO;QACLC;QACAM,aAAaL;QACbM,yBAAyBJ;QACzBK,yBAAyBN;IAC3B;AACF"}
1
+ {"version":3,"sources":["../../src/tree/useTreeSelection.ts"],"sourcesContent":["\"use client\";\n\nimport { type UseStateSetter } from \"../types.js\";\nimport { useReadonlySet } from \"../useReadonlySet.js\";\nimport { type TreeDefaultIds, type TreeItemIdSet } from \"./types.js\";\n\n/**\n * @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 * @see {@link https://react-md.dev/components/tree | Tree Demos}\n * @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?: TreeDefaultIds,\n multiSelect = false\n): Required<TreeSelection> {\n const { value, setValue, toggleValue } = useReadonlySet({\n toggleType: multiSelect ? \"multiple\" : \"single-select\",\n defaultValue: defaultSelectedIds,\n });\n\n return {\n multiSelect,\n selectedIds: value,\n toggleTreeItemSelection: toggleValue,\n selectMultipleTreeItems: setValue,\n };\n}\n"],"names":["useReadonlySet","useTreeSelection","defaultSelectedIds","multiSelect","value","setValue","toggleValue","toggleType","defaultValue","selectedIds","toggleTreeItemSelection","selectMultipleTreeItems"],"mappings":"AAAA;AAGA,SAASA,cAAc,QAAQ,uBAAuB;AAiBtD;;;;CAIC,GACD,OAAO,SAASC,iBACdC,kBAAmC,EACnCC,cAAc,KAAK;IAEnB,MAAM,EAAEC,KAAK,EAAEC,QAAQ,EAAEC,WAAW,EAAE,GAAGN,eAAe;QACtDO,YAAYJ,cAAc,aAAa;QACvCK,cAAcN;IAChB;IAEA,OAAO;QACLC;QACAM,aAAaL;QACbM,yBAAyBJ;QACzBK,yBAAyBN;IAC3B;AACF"}
@@ -100,7 +100,7 @@ export interface HighlightTextProps {
100
100
  * }
101
101
  *
102
102
  * ```
103
- * @see {@link https://next.react-md.dev/components/highlight-text | HighlightText Demos}
103
+ * @see {@link https://react-md.dev/components/highlight-text | HighlightText Demos}
104
104
  * @since 6.0.0
105
105
  */
106
106
  export declare function HighlightText(props: Readonly<HighlightTextProps>): ReactElement;
@@ -34,7 +34,7 @@ const SPECIAL_CHARACTERS_REGEXP = /[.*+?^${}()|[\]\\]/g;
34
34
  * }
35
35
  *
36
36
  * ```
37
- * @see {@link https://next.react-md.dev/components/highlight-text | HighlightText Demos}
37
+ * @see {@link https://react-md.dev/components/highlight-text | HighlightText Demos}
38
38
  * @since 6.0.0
39
39
  */ export function HighlightText(props) {
40
40
  const { query, children, highlight: Highlight = HighlightTextMark, firstMatchOnly } = props;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/typography/HighlightText.tsx"],"sourcesContent":["import {\n Children,\n type ComponentType,\n type ReactElement,\n type ReactNode,\n useMemo,\n} from \"react\";\nimport { remove as removeAccents } from \"remove-accents\";\n\nimport { HighlightTextMark } from \"./HighlightTextMark.js\";\n\n// https://developer.mozilla.org/en/docs/Web/JavaScript/Guide/Regular_Expressions#Using_special_characters\nconst SPECIAL_CHARACTERS_REGEXP = /[.*+?^${}()|[\\]\\\\]/g;\n\n/**\n * @since 6.0.0\n */\nexport interface HighlightTextMatch {\n /**\n * The cleaned query that has diacritics, leading whitespace, and trailing\n * whitespace removed.\n */\n query: string;\n\n /**\n * The raw query string that was provided.\n */\n rawQuery: string;\n\n /**\n * The full untouched text content for the HighlightText component.\n */\n rawText: string;\n\n /**\n * The current index in the {@link rawText} that is being matched against.\n */\n index: number;\n\n /**\n * The last index the query has been matched.\n */\n lastIndex: number;\n}\n\n/**\n * @since 6.0.0\n */\nexport interface HighlightTextComponentProps {\n /** {@inheritDoc HighlightTextMatch} */\n match: HighlightTextMatch;\n\n /**\n * The matched content.\n */\n children: string;\n}\n\n/**\n * @since 6.0.0\n */\nexport type HighlightTextComponent = ComponentType<HighlightTextComponentProps>;\n\n/**\n * @since 6.0.0\n */\nexport interface HighlightTextProps {\n /**\n * This prop can be used to provide a custom highlight behavior. It will be\n * provided the {@link HighlightTextComponentProps}\n *\n * @defaultValue `HighlightTextMark`\n */\n highlight?: HighlightTextComponent;\n\n /**\n * The query text to highlight in the children. When this is an empty string\n * or whitespace only, nothing will be highlighted.\n */\n query: string;\n\n /**\n * The content to highlight based on the query text where highlighting only\n * works for text children. The component will attempt to find all child text\n * using the `React.Children` API, but might be inconsistent.\n */\n children: ReactNode;\n\n /**\n * Set to `true` if only the first match should be highlighted instead of all\n * occurrences.\n *\n * @defaultValue `false`\n */\n firstMatchOnly?: boolean;\n}\n\n/**\n * The `HighlightText` component can be used to highlight text matching the\n * provided query ignoring case.\n *\n * @example Simple Example\n * ```tsx\n * import { HighlightText } from \"@react-md/core/typography/HighlightText\";\n * import { Typography } from \"@react-md/core/typography/Typography\";\n * import { type ReactElement } from \"react\";\n *\n * export default function SimpleExample(): ReactElement {\n * return (\n * <Typography>\n * <HighlightText query=\"lorem ipsum\">\n * Lorem ipsum dolor sit amet, consectetur adipiscing elit. In eget metus\n * ut mi mattis dapibus. Praesent interdum sapien ut posuere convallis.\n * Donec et tristique ex. Aliquam erat volutpat. Donec sit amet dui\n * egestas, tempus quam id, hendrerit risus. Nullam tincidunt quam ut dui\n * aliquet ultricies. Lorem ipsum dolor sit amet, consectetur adipiscing\n * elit. Sed rhoncus, purus vitae tincidunt placerat, quam diam lobortis\n * magna, et aliquam ante diam id nunc. Cras blandit leo eu nisi\n * elementum, nec gravida ligula pharetra. Etiam molestie luctus orci,\n * vel hendrerit lacus eleifend ut. Nullam placerat dolor ac mi congue,\n * non auctor metus consectetur. Ut pretium mollis vulputate.\n * </HighlightText>\n * </Typography>\n * );\n * }\n *\n * ```\n * @see {@link https://next.react-md.dev/components/highlight-text | HighlightText Demos}\n * @since 6.0.0\n */\nexport function HighlightText(\n props: Readonly<HighlightTextProps>\n): ReactElement {\n const {\n query,\n children,\n highlight: Highlight = HighlightTextMark,\n firstMatchOnly,\n } = props;\n\n return (\n <>\n {useMemo<ReactNode>(\n () =>\n Children.map(children, (child) => {\n if (!query || !child || typeof child !== \"string\") {\n return child;\n }\n\n const cleanQuery = removeAccents(query).trim();\n if (!cleanQuery) {\n return <>{child}</>;\n }\n\n const parts: ReactNode[] = [];\n const text = removeAccents(child).trim();\n const regex = new RegExp(\n \"(\" + cleanQuery.replace(SPECIAL_CHARACTERS_REGEXP, \"\\\\$&\") + \")\",\n \"gi\"\n );\n\n let match: RegExpExecArray | null;\n let lastIndex = 0;\n while ((match = regex.exec(text)) !== null) {\n const { index } = match;\n if (index > lastIndex) {\n parts.push(child.slice(lastIndex, index));\n }\n\n ({ lastIndex } = regex);\n parts.push(\n <Highlight\n key={index}\n match={{\n index,\n lastIndex,\n query: cleanQuery,\n rawQuery: query,\n rawText: child,\n }}\n >\n {child.slice(index, lastIndex)}\n </Highlight>\n );\n\n if (firstMatchOnly) {\n break;\n }\n }\n\n if (lastIndex < child.length) {\n parts.push(child.slice(lastIndex));\n }\n\n return parts;\n }),\n [Highlight, children, firstMatchOnly, query]\n )}\n </>\n );\n}\n"],"names":["Children","useMemo","remove","removeAccents","HighlightTextMark","SPECIAL_CHARACTERS_REGEXP","HighlightText","props","query","children","highlight","Highlight","firstMatchOnly","map","child","cleanQuery","trim","parts","text","regex","RegExp","replace","match","lastIndex","exec","index","push","slice","rawQuery","rawText","length"],"mappings":";AAAA,SACEA,QAAQ,EAIRC,OAAO,QACF,QAAQ;AACf,SAASC,UAAUC,aAAa,QAAQ,iBAAiB;AAEzD,SAASC,iBAAiB,QAAQ,yBAAyB;AAE3D,0GAA0G;AAC1G,MAAMC,4BAA4B;AAqFlC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAgCC,GACD,OAAO,SAASC,cACdC,KAAmC;IAEnC,MAAM,EACJC,KAAK,EACLC,QAAQ,EACRC,WAAWC,YAAYP,iBAAiB,EACxCQ,cAAc,EACf,GAAGL;IAEJ,qBACE;kBACGN,QACC,IACED,SAASa,GAAG,CAACJ,UAAU,CAACK;gBACtB,IAAI,CAACN,SAAS,CAACM,SAAS,OAAOA,UAAU,UAAU;oBACjD,OAAOA;gBACT;gBAEA,MAAMC,aAAaZ,cAAcK,OAAOQ,IAAI;gBAC5C,IAAI,CAACD,YAAY;oBACf,qBAAO;kCAAGD;;gBACZ;gBAEA,MAAMG,QAAqB,EAAE;gBAC7B,MAAMC,OAAOf,cAAcW,OAAOE,IAAI;gBACtC,MAAMG,QAAQ,IAAIC,OAChB,MAAML,WAAWM,OAAO,CAAChB,2BAA2B,UAAU,KAC9D;gBAGF,IAAIiB;gBACJ,IAAIC,YAAY;gBAChB,MAAO,AAACD,CAAAA,QAAQH,MAAMK,IAAI,CAACN,KAAI,MAAO,KAAM;oBAC1C,MAAM,EAAEO,KAAK,EAAE,GAAGH;oBAClB,IAAIG,QAAQF,WAAW;wBACrBN,MAAMS,IAAI,CAACZ,MAAMa,KAAK,CAACJ,WAAWE;oBACpC;oBAEC,CAAA,EAAEF,SAAS,EAAE,GAAGJ,KAAI;oBACrBF,MAAMS,IAAI,eACR,KAACf;wBAECW,OAAO;4BACLG;4BACAF;4BACAf,OAAOO;4BACPa,UAAUpB;4BACVqB,SAASf;wBACX;kCAECA,MAAMa,KAAK,CAACF,OAAOF;uBATfE;oBAaT,IAAIb,gBAAgB;wBAClB;oBACF;gBACF;gBAEA,IAAIW,YAAYT,MAAMgB,MAAM,EAAE;oBAC5Bb,MAAMS,IAAI,CAACZ,MAAMa,KAAK,CAACJ;gBACzB;gBAEA,OAAON;YACT,IACF;YAACN;YAAWF;YAAUG;YAAgBJ;SAAM;;AAIpD"}
1
+ {"version":3,"sources":["../../src/typography/HighlightText.tsx"],"sourcesContent":["import {\n Children,\n type ComponentType,\n type ReactElement,\n type ReactNode,\n useMemo,\n} from \"react\";\nimport { remove as removeAccents } from \"remove-accents\";\n\nimport { HighlightTextMark } from \"./HighlightTextMark.js\";\n\n// https://developer.mozilla.org/en/docs/Web/JavaScript/Guide/Regular_Expressions#Using_special_characters\nconst SPECIAL_CHARACTERS_REGEXP = /[.*+?^${}()|[\\]\\\\]/g;\n\n/**\n * @since 6.0.0\n */\nexport interface HighlightTextMatch {\n /**\n * The cleaned query that has diacritics, leading whitespace, and trailing\n * whitespace removed.\n */\n query: string;\n\n /**\n * The raw query string that was provided.\n */\n rawQuery: string;\n\n /**\n * The full untouched text content for the HighlightText component.\n */\n rawText: string;\n\n /**\n * The current index in the {@link rawText} that is being matched against.\n */\n index: number;\n\n /**\n * The last index the query has been matched.\n */\n lastIndex: number;\n}\n\n/**\n * @since 6.0.0\n */\nexport interface HighlightTextComponentProps {\n /** {@inheritDoc HighlightTextMatch} */\n match: HighlightTextMatch;\n\n /**\n * The matched content.\n */\n children: string;\n}\n\n/**\n * @since 6.0.0\n */\nexport type HighlightTextComponent = ComponentType<HighlightTextComponentProps>;\n\n/**\n * @since 6.0.0\n */\nexport interface HighlightTextProps {\n /**\n * This prop can be used to provide a custom highlight behavior. It will be\n * provided the {@link HighlightTextComponentProps}\n *\n * @defaultValue `HighlightTextMark`\n */\n highlight?: HighlightTextComponent;\n\n /**\n * The query text to highlight in the children. When this is an empty string\n * or whitespace only, nothing will be highlighted.\n */\n query: string;\n\n /**\n * The content to highlight based on the query text where highlighting only\n * works for text children. The component will attempt to find all child text\n * using the `React.Children` API, but might be inconsistent.\n */\n children: ReactNode;\n\n /**\n * Set to `true` if only the first match should be highlighted instead of all\n * occurrences.\n *\n * @defaultValue `false`\n */\n firstMatchOnly?: boolean;\n}\n\n/**\n * The `HighlightText` component can be used to highlight text matching the\n * provided query ignoring case.\n *\n * @example Simple Example\n * ```tsx\n * import { HighlightText } from \"@react-md/core/typography/HighlightText\";\n * import { Typography } from \"@react-md/core/typography/Typography\";\n * import { type ReactElement } from \"react\";\n *\n * export default function SimpleExample(): ReactElement {\n * return (\n * <Typography>\n * <HighlightText query=\"lorem ipsum\">\n * Lorem ipsum dolor sit amet, consectetur adipiscing elit. In eget metus\n * ut mi mattis dapibus. Praesent interdum sapien ut posuere convallis.\n * Donec et tristique ex. Aliquam erat volutpat. Donec sit amet dui\n * egestas, tempus quam id, hendrerit risus. Nullam tincidunt quam ut dui\n * aliquet ultricies. Lorem ipsum dolor sit amet, consectetur adipiscing\n * elit. Sed rhoncus, purus vitae tincidunt placerat, quam diam lobortis\n * magna, et aliquam ante diam id nunc. Cras blandit leo eu nisi\n * elementum, nec gravida ligula pharetra. Etiam molestie luctus orci,\n * vel hendrerit lacus eleifend ut. Nullam placerat dolor ac mi congue,\n * non auctor metus consectetur. Ut pretium mollis vulputate.\n * </HighlightText>\n * </Typography>\n * );\n * }\n *\n * ```\n * @see {@link https://react-md.dev/components/highlight-text | HighlightText Demos}\n * @since 6.0.0\n */\nexport function HighlightText(\n props: Readonly<HighlightTextProps>\n): ReactElement {\n const {\n query,\n children,\n highlight: Highlight = HighlightTextMark,\n firstMatchOnly,\n } = props;\n\n return (\n <>\n {useMemo<ReactNode>(\n () =>\n Children.map(children, (child) => {\n if (!query || !child || typeof child !== \"string\") {\n return child;\n }\n\n const cleanQuery = removeAccents(query).trim();\n if (!cleanQuery) {\n return <>{child}</>;\n }\n\n const parts: ReactNode[] = [];\n const text = removeAccents(child).trim();\n const regex = new RegExp(\n \"(\" + cleanQuery.replace(SPECIAL_CHARACTERS_REGEXP, \"\\\\$&\") + \")\",\n \"gi\"\n );\n\n let match: RegExpExecArray | null;\n let lastIndex = 0;\n while ((match = regex.exec(text)) !== null) {\n const { index } = match;\n if (index > lastIndex) {\n parts.push(child.slice(lastIndex, index));\n }\n\n ({ lastIndex } = regex);\n parts.push(\n <Highlight\n key={index}\n match={{\n index,\n lastIndex,\n query: cleanQuery,\n rawQuery: query,\n rawText: child,\n }}\n >\n {child.slice(index, lastIndex)}\n </Highlight>\n );\n\n if (firstMatchOnly) {\n break;\n }\n }\n\n if (lastIndex < child.length) {\n parts.push(child.slice(lastIndex));\n }\n\n return parts;\n }),\n [Highlight, children, firstMatchOnly, query]\n )}\n </>\n );\n}\n"],"names":["Children","useMemo","remove","removeAccents","HighlightTextMark","SPECIAL_CHARACTERS_REGEXP","HighlightText","props","query","children","highlight","Highlight","firstMatchOnly","map","child","cleanQuery","trim","parts","text","regex","RegExp","replace","match","lastIndex","exec","index","push","slice","rawQuery","rawText","length"],"mappings":";AAAA,SACEA,QAAQ,EAIRC,OAAO,QACF,QAAQ;AACf,SAASC,UAAUC,aAAa,QAAQ,iBAAiB;AAEzD,SAASC,iBAAiB,QAAQ,yBAAyB;AAE3D,0GAA0G;AAC1G,MAAMC,4BAA4B;AAqFlC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAgCC,GACD,OAAO,SAASC,cACdC,KAAmC;IAEnC,MAAM,EACJC,KAAK,EACLC,QAAQ,EACRC,WAAWC,YAAYP,iBAAiB,EACxCQ,cAAc,EACf,GAAGL;IAEJ,qBACE;kBACGN,QACC,IACED,SAASa,GAAG,CAACJ,UAAU,CAACK;gBACtB,IAAI,CAACN,SAAS,CAACM,SAAS,OAAOA,UAAU,UAAU;oBACjD,OAAOA;gBACT;gBAEA,MAAMC,aAAaZ,cAAcK,OAAOQ,IAAI;gBAC5C,IAAI,CAACD,YAAY;oBACf,qBAAO;kCAAGD;;gBACZ;gBAEA,MAAMG,QAAqB,EAAE;gBAC7B,MAAMC,OAAOf,cAAcW,OAAOE,IAAI;gBACtC,MAAMG,QAAQ,IAAIC,OAChB,MAAML,WAAWM,OAAO,CAAChB,2BAA2B,UAAU,KAC9D;gBAGF,IAAIiB;gBACJ,IAAIC,YAAY;gBAChB,MAAO,AAACD,CAAAA,QAAQH,MAAMK,IAAI,CAACN,KAAI,MAAO,KAAM;oBAC1C,MAAM,EAAEO,KAAK,EAAE,GAAGH;oBAClB,IAAIG,QAAQF,WAAW;wBACrBN,MAAMS,IAAI,CAACZ,MAAMa,KAAK,CAACJ,WAAWE;oBACpC;oBAEC,CAAA,EAAEF,SAAS,EAAE,GAAGJ,KAAI;oBACrBF,MAAMS,IAAI,eACR,KAACf;wBAECW,OAAO;4BACLG;4BACAF;4BACAf,OAAOO;4BACPa,UAAUpB;4BACVqB,SAASf;wBACX;kCAECA,MAAMa,KAAK,CAACF,OAAOF;uBATfE;oBAaT,IAAIb,gBAAgB;wBAClB;oBACF;gBACF;gBAEA,IAAIW,YAAYT,MAAMgB,MAAM,EAAE;oBAC5Bb,MAAMS,IAAI,CAACZ,MAAMa,KAAK,CAACJ;gBACzB;gBAEA,OAAON;YACT,IACF;YAACN;YAAWF;YAAUG;YAAgBJ;SAAM;;AAIpD"}
@@ -22,7 +22,7 @@ export interface MarkProps extends HTMLAttributes<HTMLElement> {
22
22
  * }
23
23
  * ```
24
24
  *
25
- * @see {@link https://next.react-md.dev/components/mark | Mark Demos}
25
+ * @see {@link https://react-md.dev/components/mark | Mark Demos}
26
26
  * @since 6.0.0
27
27
  */
28
28
  export declare const Mark: import("react").ForwardRefExoticComponent<MarkProps & import("react").RefAttributes<HTMLElement>>;
@@ -18,7 +18,7 @@ import { mark } from "./markStyles.js";
18
18
  * }
19
19
  * ```
20
20
  *
21
- * @see {@link https://next.react-md.dev/components/mark | Mark Demos}
21
+ * @see {@link https://react-md.dev/components/mark | Mark Demos}
22
22
  * @since 6.0.0
23
23
  */ export const Mark = /*#__PURE__*/ forwardRef(function Mark(props, ref) {
24
24
  const { children, className, ...remaining } = props;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/typography/Mark.tsx"],"sourcesContent":["import { type HTMLAttributes, type ReactNode, forwardRef } from \"react\";\n\nimport { mark } from \"./markStyles.js\";\n\n/**\n * @since 6.0.0\n */\nexport interface MarkProps extends HTMLAttributes<HTMLElement> {\n children: ReactNode;\n}\n\n/**\n * The `Mark` component can be used in place of the `mark` HTMLElement with\n * some default styles.\n *\n * @example Simple Example\n * ```tsx\n * import { Mark } from \"@react-md/core/typography/Mark\";\n *\n * export function Example() {\n * return (\n * <>\n * Some text <Mark>that has highlights</Mark> and some other text.\n * </>\n * );\n * }\n * ```\n *\n * @see {@link https://next.react-md.dev/components/mark | Mark Demos}\n * @since 6.0.0\n */\nexport const Mark = forwardRef<HTMLElement, MarkProps>(\n function Mark(props, ref) {\n const { children, className, ...remaining } = props;\n return (\n <mark {...remaining} ref={ref} className={mark({ className })}>\n {children}\n </mark>\n );\n }\n);\n"],"names":["forwardRef","mark","Mark","props","ref","children","className","remaining"],"mappings":";AAAA,SAA8CA,UAAU,QAAQ,QAAQ;AAExE,SAASC,IAAI,QAAQ,kBAAkB;AASvC;;;;;;;;;;;;;;;;;;;CAmBC,GACD,OAAO,MAAMC,qBAAOF,WAClB,SAASE,KAAKC,KAAK,EAAEC,GAAG;IACtB,MAAM,EAAEC,QAAQ,EAAEC,SAAS,EAAE,GAAGC,WAAW,GAAGJ;IAC9C,qBACE,KAACF;QAAM,GAAGM,SAAS;QAAEH,KAAKA;QAAKE,WAAWL,KAAK;YAAEK;QAAU;kBACxDD;;AAGP,GACA"}
1
+ {"version":3,"sources":["../../src/typography/Mark.tsx"],"sourcesContent":["import { type HTMLAttributes, type ReactNode, forwardRef } from \"react\";\n\nimport { mark } from \"./markStyles.js\";\n\n/**\n * @since 6.0.0\n */\nexport interface MarkProps extends HTMLAttributes<HTMLElement> {\n children: ReactNode;\n}\n\n/**\n * The `Mark` component can be used in place of the `mark` HTMLElement with\n * some default styles.\n *\n * @example Simple Example\n * ```tsx\n * import { Mark } from \"@react-md/core/typography/Mark\";\n *\n * export function Example() {\n * return (\n * <>\n * Some text <Mark>that has highlights</Mark> and some other text.\n * </>\n * );\n * }\n * ```\n *\n * @see {@link https://react-md.dev/components/mark | Mark Demos}\n * @since 6.0.0\n */\nexport const Mark = forwardRef<HTMLElement, MarkProps>(\n function Mark(props, ref) {\n const { children, className, ...remaining } = props;\n return (\n <mark {...remaining} ref={ref} className={mark({ className })}>\n {children}\n </mark>\n );\n }\n);\n"],"names":["forwardRef","mark","Mark","props","ref","children","className","remaining"],"mappings":";AAAA,SAA8CA,UAAU,QAAQ,QAAQ;AAExE,SAASC,IAAI,QAAQ,kBAAkB;AASvC;;;;;;;;;;;;;;;;;;;CAmBC,GACD,OAAO,MAAMC,qBAAOF,WAClB,SAASE,KAAKC,KAAK,EAAEC,GAAG;IACtB,MAAM,EAAEC,QAAQ,EAAEC,SAAS,EAAE,GAAGC,WAAW,GAAGJ;IAC9C,qBACE,KAACF;QAAM,GAAGM,SAAS;QAAEH,KAAKA;QAAKE,WAAWL,KAAK;YAAEK;QAAU;kBACxDD;;AAGP,GACA"}
@@ -41,6 +41,6 @@ export interface SrOnlyProps extends HTMLAttributes<TypographyHTMLElement> {
41
41
  * }
42
42
  * ```
43
43
  *
44
- * @see {@link https://next.react-md.dev/components/sr-only | SrOnly Demos}
44
+ * @see {@link https://react-md.dev/components/sr-only | SrOnly Demos}
45
45
  */
46
46
  export declare const SrOnly: import("react").ForwardRefExoticComponent<SrOnlyProps & import("react").RefAttributes<TypographyHTMLElement>>;
@@ -24,7 +24,7 @@ import { cssUtils } from "../cssUtils.js";
24
24
  * }
25
25
  * ```
26
26
  *
27
- * @see {@link https://next.react-md.dev/components/sr-only | SrOnly Demos}
27
+ * @see {@link https://react-md.dev/components/sr-only | SrOnly Demos}
28
28
  */ export const SrOnly = /*#__PURE__*/ forwardRef(function SrOnly(props, ref) {
29
29
  const { as: AsComponent = "span", className, phoneOnly, focusable, children, tabIndex, ...remaining } = props;
30
30
  // do some type-casting so ref works
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/typography/SrOnly.tsx"],"sourcesContent":["import { type ElementType, type HTMLAttributes, forwardRef } from \"react\";\n\nimport { cssUtils } from \"../cssUtils.js\";\nimport {\n type CustomTypographyComponent,\n type TypographyHTMLElement,\n} from \"./Typography.js\";\n\nexport interface SrOnlyProps extends HTMLAttributes<TypographyHTMLElement> {\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 * The `SrOnly` component is used to render content that is only visible to\n * screen readers.\n *\n * @example Simple Example\n * ```tsx\n * import { SrOnly } from \"@react-md/core/typography/SrOnly\";\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 *\n * @see {@link https://next.react-md.dev/components/sr-only | SrOnly Demos}\n */\nexport const SrOnly = forwardRef<TypographyHTMLElement, SrOnlyProps>(\n function SrOnly(props, ref) {\n const {\n as: AsComponent = \"span\",\n className,\n phoneOnly,\n focusable,\n children,\n tabIndex,\n ...remaining\n } = props;\n\n // do some type-casting so ref works\n const Component = AsComponent as ElementType;\n\n return (\n <Component\n {...remaining}\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 </Component>\n );\n }\n);\n"],"names":["forwardRef","cssUtils","SrOnly","props","ref","as","AsComponent","className","phoneOnly","focusable","children","tabIndex","remaining","Component","undefined","srOnly"],"mappings":";AAAA,SAAgDA,UAAU,QAAQ,QAAQ;AAE1E,SAASC,QAAQ,QAAQ,iBAAiB;AA2B1C;;;;;;;;;;;;;;;;;;;;;;;;CAwBC,GACD,OAAO,MAAMC,uBAASF,WACpB,SAASE,OAAOC,KAAK,EAAEC,GAAG;IACxB,MAAM,EACJC,IAAIC,cAAc,MAAM,EACxBC,SAAS,EACTC,SAAS,EACTC,SAAS,EACTC,QAAQ,EACRC,QAAQ,EACR,GAAGC,WACJ,GAAGT;IAEJ,oCAAoC;IACpC,MAAMU,YAAYP;IAElB,qBACE,KAACO;QACE,GAAGD,SAAS;QACbR,KAAKA;QACLO,UAAUA,YAAaF,CAAAA,YAAY,IAAIK,SAAQ;QAC/CP,WAAWN,SAAS;YAClBc,QAAQN,YAAY,cAAcD,YAAY,UAAU;YACxDD;QACF;kBAECG;;AAGP,GACA"}
1
+ {"version":3,"sources":["../../src/typography/SrOnly.tsx"],"sourcesContent":["import { type ElementType, type HTMLAttributes, forwardRef } from \"react\";\n\nimport { cssUtils } from \"../cssUtils.js\";\nimport {\n type CustomTypographyComponent,\n type TypographyHTMLElement,\n} from \"./Typography.js\";\n\nexport interface SrOnlyProps extends HTMLAttributes<TypographyHTMLElement> {\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 * The `SrOnly` component is used to render content that is only visible to\n * screen readers.\n *\n * @example Simple Example\n * ```tsx\n * import { SrOnly } from \"@react-md/core/typography/SrOnly\";\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 *\n * @see {@link https://react-md.dev/components/sr-only | SrOnly Demos}\n */\nexport const SrOnly = forwardRef<TypographyHTMLElement, SrOnlyProps>(\n function SrOnly(props, ref) {\n const {\n as: AsComponent = \"span\",\n className,\n phoneOnly,\n focusable,\n children,\n tabIndex,\n ...remaining\n } = props;\n\n // do some type-casting so ref works\n const Component = AsComponent as ElementType;\n\n return (\n <Component\n {...remaining}\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 </Component>\n );\n }\n);\n"],"names":["forwardRef","cssUtils","SrOnly","props","ref","as","AsComponent","className","phoneOnly","focusable","children","tabIndex","remaining","Component","undefined","srOnly"],"mappings":";AAAA,SAAgDA,UAAU,QAAQ,QAAQ;AAE1E,SAASC,QAAQ,QAAQ,iBAAiB;AA2B1C;;;;;;;;;;;;;;;;;;;;;;;;CAwBC,GACD,OAAO,MAAMC,uBAASF,WACpB,SAASE,OAAOC,KAAK,EAAEC,GAAG;IACxB,MAAM,EACJC,IAAIC,cAAc,MAAM,EACxBC,SAAS,EACTC,SAAS,EACTC,SAAS,EACTC,QAAQ,EACRC,QAAQ,EACR,GAAGC,WACJ,GAAGT;IAEJ,oCAAoC;IACpC,MAAMU,YAAYP;IAElB,qBACE,KAACO;QACE,GAAGD,SAAS;QACbR,KAAKA;QACLO,UAAUA,YAAaF,CAAAA,YAAY,IAAIK,SAAQ;QAC/CP,WAAWN,SAAS;YAClBc,QAAQN,YAAY,cAAcD,YAAY,UAAU;YACxDD;QACF;kBAECG;;AAGP,GACA"}
@@ -39,7 +39,7 @@ export interface TextContainerProps extends HTMLAttributes<HTMLDivElement>, Text
39
39
  * }
40
40
  * ```
41
41
  *
42
- * @see {@link https://next.react-md.dev/components/text-container | TextContainer Demos}
42
+ * @see {@link https://react-md.dev/components/text-container | TextContainer Demos}
43
43
  * @see {@link textContainer} If you only want to apply this class to an
44
44
  * element.
45
45
  * @since 6.0.0 Removed the `size` option since there is no longer a
@@ -26,7 +26,7 @@ import { textContainer } from "./textContainerStyles.js";
26
26
  * }
27
27
  * ```
28
28
  *
29
- * @see {@link https://next.react-md.dev/components/text-container | TextContainer Demos}
29
+ * @see {@link https://react-md.dev/components/text-container | TextContainer Demos}
30
30
  * @see {@link textContainer} If you only want to apply this class to an
31
31
  * element.
32
32
  * @since 6.0.0 Removed the `size` option since there is no longer a
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/typography/TextContainer.tsx"],"sourcesContent":["import { type HTMLAttributes, forwardRef } from \"react\";\n\nimport {\n type TextContainerClassNameOptions,\n textContainer,\n} from \"./textContainerStyles.js\";\n\ndeclare module \"react\" {\n interface CSSProperties {\n \"--rmd-line-length\"?: string | number;\n \"--rmd-text-container-padding\"?: string | number;\n }\n}\n\n/**\n * @since 6.0.0 Removed the `size` option since there is no longer a\n * different line-length for mobile and desktop.\n * @since 6.0.0 Removed the `clone` prop and the children render function\n * behavior. Use the `textContainer` class name utility instead.\n */\nexport interface TextContainerProps\n extends HTMLAttributes<HTMLDivElement>,\n TextContainerClassNameOptions {}\n\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 Simple Example\n * ```tsx\n * import { TextContainer } from \"@react-md/core/typography/TextContainer\";\n * import { Typography } from \"@react-md/core/typography/Typography\";\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 https://next.react-md.dev/components/text-container | TextContainer Demos}\n * @see {@link textContainer} If you only want to apply this class to an\n * element.\n * @since 6.0.0 Removed the `size` option since there is no longer a\n * different line-length for mobile and desktop.\n * @since 6.0.0 Removed the `clone` prop and the children render function\n * behavior. Use the `textContainer` class name utility instead.\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":["forwardRef","textContainer","TextContainer","props","ref","className","children","remaining","div"],"mappings":";AAAA,SAA8BA,UAAU,QAAQ,QAAQ;AAExD,SAEEC,aAAa,QACR,2BAA2B;AAmBlC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAgCC,GACD,OAAO,MAAMC,8BAAgBF,WAC3B,SAASE,cAAcC,KAAK,EAAEC,GAAG;IAC/B,MAAM,EAAEC,SAAS,EAAEC,QAAQ,EAAE,GAAGC,WAAW,GAAGJ;IAE9C,qBACE,KAACK;QAAK,GAAGD,SAAS;QAAEH,KAAKA;QAAKC,WAAWJ,cAAc;YAAEI;QAAU;kBAChEC;;AAGP,GACA"}
1
+ {"version":3,"sources":["../../src/typography/TextContainer.tsx"],"sourcesContent":["import { type HTMLAttributes, forwardRef } from \"react\";\n\nimport {\n type TextContainerClassNameOptions,\n textContainer,\n} from \"./textContainerStyles.js\";\n\ndeclare module \"react\" {\n interface CSSProperties {\n \"--rmd-line-length\"?: string | number;\n \"--rmd-text-container-padding\"?: string | number;\n }\n}\n\n/**\n * @since 6.0.0 Removed the `size` option since there is no longer a\n * different line-length for mobile and desktop.\n * @since 6.0.0 Removed the `clone` prop and the children render function\n * behavior. Use the `textContainer` class name utility instead.\n */\nexport interface TextContainerProps\n extends HTMLAttributes<HTMLDivElement>,\n TextContainerClassNameOptions {}\n\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 Simple Example\n * ```tsx\n * import { TextContainer } from \"@react-md/core/typography/TextContainer\";\n * import { Typography } from \"@react-md/core/typography/Typography\";\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 https://react-md.dev/components/text-container | TextContainer Demos}\n * @see {@link textContainer} If you only want to apply this class to an\n * element.\n * @since 6.0.0 Removed the `size` option since there is no longer a\n * different line-length for mobile and desktop.\n * @since 6.0.0 Removed the `clone` prop and the children render function\n * behavior. Use the `textContainer` class name utility instead.\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":["forwardRef","textContainer","TextContainer","props","ref","className","children","remaining","div"],"mappings":";AAAA,SAA8BA,UAAU,QAAQ,QAAQ;AAExD,SAEEC,aAAa,QACR,2BAA2B;AAmBlC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAgCC,GACD,OAAO,MAAMC,8BAAgBF,WAC3B,SAASE,cAAcC,KAAK,EAAEC,GAAG;IAC/B,MAAM,EAAEC,SAAS,EAAEC,QAAQ,EAAE,GAAGC,WAAW,GAAGJ;IAE9C,qBACE,KAACK;QAAK,GAAGD,SAAS;QAAEH,KAAKA;QAAKC,WAAWJ,cAAc;YAAEI;QAAU;kBAChEC;;AAGP,GACA"}
@@ -79,7 +79,7 @@ export interface TypographyProps extends HTMLAttributes<TypographyHTMLElement>,
79
79
  * }
80
80
  * ```
81
81
  *
82
- * @see {@link https://next.react-md.dev/components/typography | Typography Demos}
82
+ * @see {@link https://react-md.dev/components/typography | Typography Demos}
83
83
  * @since 6.0.0 Removed the children render function behavior . Use the
84
84
  * `typography` class name utility instead.
85
85
  */
@@ -68,7 +68,7 @@ import { typography } from "./typographyStyles.js";
68
68
  * }
69
69
  * ```
70
70
  *
71
- * @see {@link https://next.react-md.dev/components/typography | Typography Demos}
71
+ * @see {@link https://react-md.dev/components/typography | Typography Demos}
72
72
  * @since 6.0.0 Removed the children render function behavior . Use the
73
73
  * `typography` class name utility instead.
74
74
  */ export const Typography = /*#__PURE__*/ forwardRef(function Typography(props, ref) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/typography/Typography.tsx"],"sourcesContent":["import {\n type ElementType,\n type HTMLAttributes,\n type ReactElement,\n forwardRef,\n} from \"react\";\n\nimport {\n type TypographyClassNameOptions,\n type TypographyType,\n typography,\n} from \"./typographyStyles.js\";\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 * @since 4.0.0\n */\nexport type TypographyHTMLElement =\n | HTMLHeadingElement\n | HTMLParagraphElement\n | HTMLSpanElement\n | HTMLDivElement\n | HTMLAnchorElement\n | HTMLBodyElement\n | HTMLHtmlElement;\n\n/** @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\n/**\n * @since 6.0.0 Renamed `component` to `as`.\n * @since 6.0.0 Removed the children render function behavior. Use the\n * `typography` class name utility instead.\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 * @since 6.0.0 Renamed from `component`\n */\n as?: CustomTypographyComponent;\n}\n\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 All Example\n * ```tsx\n * import { Typography } from \"@react-md/core/typography/Typography\":\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 *\n * @see {@link https://next.react-md.dev/components/typography | Typography Demos}\n * @since 6.0.0 Removed the children render function behavior . Use the\n * `typography` class name utility instead.\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":["forwardRef","typography","getComponent","as","type","Typography","props","ref","className","margin","fontStyle","fontWeight","textAlign","textColor","textDecoration","textTransform","textOverflow","children","remaining","Component"],"mappings":";AAAA,SAIEA,UAAU,QACL,QAAQ;AAEf,SAGEC,UAAU,QACL,wBAAwB;AAuB/B,cAAc,GACd,SAASC,aACPC,EAAyC,EACzCC,IAAoB;IAEpB,IAAID,IAAI;QACN,OAAOA;IACT;IAEA,OAAQC;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;AAiCA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA0CC,GACD,OAAO,MAAMC,2BAAaL,WACxB,SAASK,WAAWC,KAAK,EAAEC,GAAG;IAC5B,MAAM,EACJJ,EAAE,EACFC,OAAO,QAAQ,EACfI,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,YAAYjB,aAAaC,IAAIC;IACnC,qBACE,KAACe;QACE,GAAGD,SAAS;QACbX,KAAKA;QACLC,WAAWP,WAAW;YACpBG;YACAK;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAR;QACF;kBAECS;;AAGP,GACA"}
1
+ {"version":3,"sources":["../../src/typography/Typography.tsx"],"sourcesContent":["import {\n type ElementType,\n type HTMLAttributes,\n type ReactElement,\n forwardRef,\n} from \"react\";\n\nimport {\n type TypographyClassNameOptions,\n type TypographyType,\n typography,\n} from \"./typographyStyles.js\";\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 * @since 4.0.0\n */\nexport type TypographyHTMLElement =\n | HTMLHeadingElement\n | HTMLParagraphElement\n | HTMLSpanElement\n | HTMLDivElement\n | HTMLAnchorElement\n | HTMLBodyElement\n | HTMLHtmlElement;\n\n/** @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\n/**\n * @since 6.0.0 Renamed `component` to `as`.\n * @since 6.0.0 Removed the children render function behavior. Use the\n * `typography` class name utility instead.\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 * @since 6.0.0 Renamed from `component`\n */\n as?: CustomTypographyComponent;\n}\n\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 All Example\n * ```tsx\n * import { Typography } from \"@react-md/core/typography/Typography\":\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 *\n * @see {@link https://react-md.dev/components/typography | Typography Demos}\n * @since 6.0.0 Removed the children render function behavior . Use the\n * `typography` class name utility instead.\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":["forwardRef","typography","getComponent","as","type","Typography","props","ref","className","margin","fontStyle","fontWeight","textAlign","textColor","textDecoration","textTransform","textOverflow","children","remaining","Component"],"mappings":";AAAA,SAIEA,UAAU,QACL,QAAQ;AAEf,SAGEC,UAAU,QACL,wBAAwB;AAuB/B,cAAc,GACd,SAASC,aACPC,EAAyC,EACzCC,IAAoB;IAEpB,IAAID,IAAI;QACN,OAAOA;IACT;IAEA,OAAQC;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;AAiCA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA0CC,GACD,OAAO,MAAMC,2BAAaL,WACxB,SAASK,WAAWC,KAAK,EAAEC,GAAG;IAC5B,MAAM,EACJJ,EAAE,EACFC,OAAO,QAAQ,EACfI,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,YAAYjB,aAAaC,IAAIC;IACnC,qBACE,KAACe;QACE,GAAGD,SAAS;QACbX,KAAKA;QACLC,WAAWP,WAAW;YACpBG;YACAK;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAR;QACF;kBAECS;;AAGP,GACA"}
@@ -143,7 +143,7 @@ export declare const DEFAULT_WRITING_DIRECTION: () => Dir;
143
143
  * );
144
144
  * ```
145
145
  *
146
- * @see {@link https://next.react-md.dev/components/writing-direction-provider | WritingDirectionProvider Demos}
146
+ * @see {@link https://react-md.dev/components/writing-direction-provider | WritingDirectionProvider Demos}
147
147
  * @since 6.0.0 Renamed from `Dir`
148
148
  */
149
149
  export declare function WritingDirectionProvider(props: WritingDirectionProviderProps): ReactElement;
@@ -124,7 +124,7 @@ const { Provider } = context;
124
124
  * );
125
125
  * ```
126
126
  *
127
- * @see {@link https://next.react-md.dev/components/writing-direction-provider | WritingDirectionProvider Demos}
127
+ * @see {@link https://react-md.dev/components/writing-direction-provider | WritingDirectionProvider Demos}
128
128
  * @since 6.0.0 Renamed from `Dir`
129
129
  */ export function WritingDirectionProvider(props) {
130
130
  const { children, defaultDir = DEFAULT_WRITING_DIRECTION } = props;