@mui/material 6.0.0-alpha.9 → 6.0.0-beta.1

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 (752) hide show
  1. package/Accordion/Accordion.d.ts +3 -5
  2. package/Accordion/Accordion.js +3 -5
  3. package/AccordionActions/AccordionActions.d.ts +2 -2
  4. package/AccordionActions/AccordionActions.js +3 -3
  5. package/AccordionDetails/AccordionDetails.d.ts +2 -2
  6. package/AccordionDetails/AccordionDetails.js +3 -3
  7. package/AccordionSummary/AccordionSummary.d.ts +3 -3
  8. package/AccordionSummary/AccordionSummary.js +3 -3
  9. package/Alert/Alert.d.ts +15 -6
  10. package/Alert/Alert.js +3 -3
  11. package/AlertTitle/AlertTitle.d.ts +3 -3
  12. package/AlertTitle/AlertTitle.js +3 -3
  13. package/AppBar/AppBar.d.ts +3 -3
  14. package/AppBar/AppBar.js +5 -9
  15. package/Autocomplete/Autocomplete.d.ts +9 -15
  16. package/Autocomplete/Autocomplete.js +14 -27
  17. package/Avatar/Avatar.d.ts +2 -3
  18. package/Avatar/Avatar.js +3 -4
  19. package/AvatarGroup/AvatarGroup.d.ts +2 -2
  20. package/AvatarGroup/AvatarGroup.js +3 -3
  21. package/Backdrop/Backdrop.d.ts +5 -8
  22. package/Backdrop/Backdrop.js +5 -8
  23. package/Badge/Badge.d.ts +4 -4
  24. package/Badge/Badge.js +5 -5
  25. package/Badge/useBadge.d.ts +13 -0
  26. package/Badge/useBadge.js +41 -0
  27. package/Badge/useBadge.types.d.ts +40 -0
  28. package/Badge/useBadge.types.js +1 -0
  29. package/BottomNavigation/BottomNavigation.d.ts +2 -2
  30. package/BottomNavigation/BottomNavigation.js +3 -3
  31. package/BottomNavigationAction/BottomNavigationAction.d.ts +3 -3
  32. package/BottomNavigationAction/BottomNavigationAction.js +3 -3
  33. package/Box/Box.d.ts +2 -2
  34. package/Breadcrumbs/Breadcrumbs.d.ts +4 -4
  35. package/Breadcrumbs/Breadcrumbs.js +4 -4
  36. package/Button/Button.d.ts +4 -4
  37. package/Button/Button.js +3 -3
  38. package/ButtonBase/ButtonBase.d.ts +2 -2
  39. package/ButtonBase/ButtonBase.js +23 -52
  40. package/ButtonBase/TouchRipple.js +3 -3
  41. package/ButtonGroup/ButtonGroup.d.ts +2 -2
  42. package/ButtonGroup/ButtonGroup.js +3 -3
  43. package/CHANGELOG.md +363 -3
  44. package/Card/Card.d.ts +3 -3
  45. package/Card/Card.js +3 -3
  46. package/CardActionArea/CardActionArea.d.ts +3 -3
  47. package/CardActionArea/CardActionArea.js +3 -3
  48. package/CardActions/CardActions.d.ts +2 -2
  49. package/CardActions/CardActions.js +3 -3
  50. package/CardContent/CardContent.d.ts +2 -2
  51. package/CardContent/CardContent.js +3 -3
  52. package/CardHeader/CardHeader.d.ts +2 -2
  53. package/CardHeader/CardHeader.js +3 -3
  54. package/CardMedia/CardMedia.d.ts +2 -2
  55. package/CardMedia/CardMedia.js +3 -3
  56. package/Checkbox/Checkbox.d.ts +4 -4
  57. package/Checkbox/Checkbox.js +3 -3
  58. package/Chip/Chip.d.ts +5 -5
  59. package/Chip/Chip.js +3 -5
  60. package/CircularProgress/CircularProgress.d.ts +2 -2
  61. package/CircularProgress/CircularProgress.js +3 -3
  62. package/ClickAwayListener/ClickAwayListener.d.ts +47 -0
  63. package/ClickAwayListener/ClickAwayListener.js +178 -0
  64. package/ClickAwayListener/index.d.ts +2 -2
  65. package/ClickAwayListener/index.js +1 -1
  66. package/Collapse/Collapse.d.ts +5 -5
  67. package/Collapse/Collapse.js +3 -4
  68. package/Container/Container.d.ts +2 -2
  69. package/CssBaseline/CssBaseline.d.ts +2 -2
  70. package/CssBaseline/CssBaseline.js +66 -8
  71. package/DefaultPropsProvider/DefaultPropsProvider.d.ts +15 -0
  72. package/DefaultPropsProvider/DefaultPropsProvider.js +29 -0
  73. package/DefaultPropsProvider/index.d.ts +1 -0
  74. package/DefaultPropsProvider/index.js +1 -0
  75. package/DefaultPropsProvider/package.json +6 -0
  76. package/Dialog/Dialog.d.ts +3 -3
  77. package/Dialog/Dialog.js +4 -7
  78. package/DialogActions/DialogActions.d.ts +2 -2
  79. package/DialogActions/DialogActions.js +3 -3
  80. package/DialogContent/DialogContent.d.ts +2 -2
  81. package/DialogContent/DialogContent.js +3 -3
  82. package/DialogContentText/DialogContentText.d.ts +3 -3
  83. package/DialogContentText/DialogContentText.js +3 -3
  84. package/DialogTitle/DialogTitle.d.ts +3 -3
  85. package/DialogTitle/DialogTitle.js +3 -3
  86. package/Divider/Divider.d.ts +3 -3
  87. package/Divider/Divider.js +3 -3
  88. package/Drawer/Drawer.d.ts +3 -3
  89. package/Drawer/Drawer.js +3 -4
  90. package/Fab/Fab.d.ts +3 -3
  91. package/Fab/Fab.js +3 -3
  92. package/Fade/Fade.d.ts +3 -3
  93. package/Fade/Fade.js +1 -1
  94. package/FilledInput/FilledInput.d.ts +3 -3
  95. package/FilledInput/FilledInput.js +13 -11
  96. package/FilledInput/filledInputClasses.d.ts +1 -13
  97. package/FilledInput/filledInputClasses.js +1 -1
  98. package/FormControl/FormControl.d.ts +6 -6
  99. package/FormControl/FormControl.js +3 -3
  100. package/FormControlLabel/FormControlLabel.d.ts +4 -4
  101. package/FormControlLabel/FormControlLabel.js +3 -3
  102. package/FormGroup/FormGroup.d.ts +3 -3
  103. package/FormGroup/FormGroup.js +3 -3
  104. package/FormHelperText/FormHelperText.d.ts +2 -2
  105. package/FormHelperText/FormHelperText.js +3 -3
  106. package/FormLabel/FormLabel.d.ts +4 -4
  107. package/FormLabel/FormLabel.js +3 -3
  108. package/GlobalStyles/GlobalStyles.d.ts +3 -3
  109. package/Grid/Grid.d.ts +2 -2
  110. package/Grid/Grid.js +7 -13
  111. package/Grow/Grow.d.ts +5 -5
  112. package/Grow/Grow.js +1 -1
  113. package/Hidden/Hidden.d.ts +2 -2
  114. package/Hidden/hiddenCssClasses.d.ts +3 -0
  115. package/Icon/Icon.d.ts +3 -3
  116. package/Icon/Icon.js +3 -3
  117. package/IconButton/IconButton.d.ts +4 -4
  118. package/IconButton/IconButton.js +3 -5
  119. package/ImageList/ImageList.d.ts +2 -2
  120. package/ImageList/ImageList.js +3 -11
  121. package/ImageListItem/ImageListItem.d.ts +2 -2
  122. package/ImageListItem/ImageListItem.js +3 -3
  123. package/ImageListItemBar/ImageListItemBar.d.ts +2 -2
  124. package/ImageListItemBar/ImageListItemBar.js +3 -3
  125. package/InitColorSchemeScript/InitColorSchemeScript.d.ts +10 -0
  126. package/InitColorSchemeScript/InitColorSchemeScript.js +16 -0
  127. package/InitColorSchemeScript/index.d.ts +1 -0
  128. package/InitColorSchemeScript/index.js +1 -0
  129. package/InitColorSchemeScript/package.json +6 -0
  130. package/Input/Input.d.ts +3 -3
  131. package/Input/Input.js +5 -9
  132. package/InputAdornment/InputAdornment.d.ts +2 -2
  133. package/InputAdornment/InputAdornment.js +3 -5
  134. package/InputBase/InputBase.d.ts +4 -6
  135. package/InputBase/InputBase.js +33 -42
  136. package/InputLabel/InputLabel.d.ts +3 -3
  137. package/InputLabel/InputLabel.js +3 -3
  138. package/LinearProgress/LinearProgress.d.ts +2 -2
  139. package/LinearProgress/LinearProgress.js +3 -3
  140. package/Link/Link.d.ts +4 -4
  141. package/Link/Link.js +7 -18
  142. package/List/List.d.ts +3 -3
  143. package/List/List.js +3 -3
  144. package/ListItem/ListItem.d.ts +3 -3
  145. package/ListItem/ListItem.js +4 -4
  146. package/ListItemAvatar/ListItemAvatar.d.ts +2 -2
  147. package/ListItemAvatar/ListItemAvatar.js +3 -3
  148. package/ListItemButton/ListItemButton.d.ts +3 -3
  149. package/ListItemButton/ListItemButton.js +3 -3
  150. package/ListItemIcon/ListItemIcon.d.ts +2 -2
  151. package/ListItemIcon/ListItemIcon.js +3 -3
  152. package/ListItemSecondaryAction/ListItemSecondaryAction.d.ts +2 -2
  153. package/ListItemSecondaryAction/ListItemSecondaryAction.js +3 -3
  154. package/ListItemText/ListItemText.d.ts +2 -2
  155. package/ListItemText/ListItemText.js +3 -3
  156. package/ListSubheader/ListSubheader.d.ts +2 -2
  157. package/ListSubheader/ListSubheader.js +3 -3
  158. package/Menu/Menu.d.ts +4 -4
  159. package/Menu/Menu.js +5 -8
  160. package/MenuItem/MenuItem.d.ts +3 -3
  161. package/MenuItem/MenuItem.js +3 -3
  162. package/MenuList/MenuList.d.ts +4 -4
  163. package/MobileStepper/MobileStepper.d.ts +3 -3
  164. package/MobileStepper/MobileStepper.js +3 -3
  165. package/Modal/Modal.d.ts +11 -13
  166. package/Modal/Modal.js +33 -25
  167. package/Modal/ModalManager.d.ts +25 -0
  168. package/Modal/ModalManager.js +211 -0
  169. package/Modal/index.d.ts +1 -1
  170. package/Modal/index.js +1 -1
  171. package/Modal/useModal.d.ts +13 -0
  172. package/Modal/useModal.js +195 -0
  173. package/Modal/useModal.types.d.ts +115 -0
  174. package/Modal/useModal.types.js +1 -0
  175. package/NativeSelect/NativeSelect.d.ts +3 -3
  176. package/NativeSelect/NativeSelectInput.js +0 -4
  177. package/NoSsr/NoSsr.d.ts +25 -0
  178. package/NoSsr/NoSsr.js +73 -0
  179. package/NoSsr/NoSsr.types.d.ts +18 -0
  180. package/NoSsr/NoSsr.types.js +1 -0
  181. package/NoSsr/index.d.ts +3 -2
  182. package/NoSsr/index.js +1 -1
  183. package/OutlinedInput/OutlinedInput.d.ts +3 -3
  184. package/OutlinedInput/OutlinedInput.js +4 -5
  185. package/Pagination/Pagination.d.ts +2 -2
  186. package/Pagination/Pagination.js +3 -3
  187. package/PaginationItem/PaginationItem.d.ts +2 -2
  188. package/PaginationItem/PaginationItem.js +3 -3
  189. package/Paper/Paper.d.ts +3 -3
  190. package/Paper/Paper.js +3 -4
  191. package/PigmentContainer/PigmentContainer.d.ts +55 -0
  192. package/PigmentContainer/PigmentContainer.js +98 -0
  193. package/PigmentContainer/index.d.ts +3 -0
  194. package/PigmentContainer/index.js +3 -0
  195. package/PigmentContainer/package.json +6 -0
  196. package/PigmentGrid/PigmentGrid.d.ts +108 -0
  197. package/PigmentGrid/PigmentGrid.js +149 -0
  198. package/PigmentGrid/index.d.ts +3 -0
  199. package/PigmentGrid/index.js +3 -0
  200. package/{useTouchRipple → PigmentGrid}/package.json +1 -1
  201. package/PigmentHidden/PigmentHidden.d.ts +97 -0
  202. package/PigmentHidden/PigmentHidden.js +278 -0
  203. package/PigmentHidden/index.d.ts +2 -0
  204. package/PigmentHidden/index.js +2 -0
  205. package/PigmentHidden/package.json +6 -0
  206. package/PigmentStack/PigmentStack.d.ts +51 -0
  207. package/PigmentStack/PigmentStack.js +81 -0
  208. package/PigmentStack/index.d.ts +3 -0
  209. package/PigmentStack/index.js +3 -0
  210. package/PigmentStack/package.json +6 -0
  211. package/Popover/Popover.d.ts +20 -25
  212. package/Popover/Popover.js +30 -29
  213. package/Popper/BasePopper.d.ts +7 -0
  214. package/Popper/BasePopper.js +370 -0
  215. package/Popper/BasePopper.types.d.ts +130 -0
  216. package/Popper/BasePopper.types.js +1 -0
  217. package/Popper/Popper.d.ts +5 -5
  218. package/Popper/Popper.js +11 -10
  219. package/Popper/index.d.ts +2 -1
  220. package/Popper/index.js +2 -1
  221. package/Popper/popperClasses.d.ts +8 -0
  222. package/Popper/popperClasses.js +7 -0
  223. package/Portal/Portal.d.ts +16 -0
  224. package/Portal/Portal.js +92 -0
  225. package/Portal/Portal.types.d.ts +23 -0
  226. package/Portal/Portal.types.js +1 -0
  227. package/Portal/index.d.ts +3 -2
  228. package/Portal/index.js +1 -1
  229. package/Radio/Radio.d.ts +3 -3
  230. package/Radio/Radio.js +3 -3
  231. package/RadioGroup/RadioGroup.d.ts +3 -3
  232. package/Rating/Rating.d.ts +2 -2
  233. package/Rating/Rating.js +8 -15
  234. package/ScopedCssBaseline/ScopedCssBaseline.d.ts +2 -2
  235. package/ScopedCssBaseline/ScopedCssBaseline.js +24 -11
  236. package/Select/Select.d.ts +3 -3
  237. package/Skeleton/Skeleton.d.ts +2 -2
  238. package/Skeleton/Skeleton.js +3 -3
  239. package/Slide/Slide.d.ts +4 -4
  240. package/Slide/Slide.js +1 -1
  241. package/Slider/Slider.d.ts +5 -5
  242. package/Slider/Slider.js +6 -5
  243. package/Slider/useSlider.d.ts +14 -0
  244. package/Slider/useSlider.js +647 -0
  245. package/Slider/useSlider.types.d.ts +228 -0
  246. package/Slider/useSlider.types.js +1 -0
  247. package/Snackbar/Snackbar.d.ts +3 -3
  248. package/Snackbar/Snackbar.js +6 -7
  249. package/Snackbar/useSnackbar.d.ts +14 -0
  250. package/Snackbar/useSnackbar.js +133 -0
  251. package/Snackbar/useSnackbar.types.d.ts +60 -0
  252. package/Snackbar/useSnackbar.types.js +1 -0
  253. package/SnackbarContent/SnackbarContent.d.ts +3 -3
  254. package/SnackbarContent/SnackbarContent.js +3 -3
  255. package/SpeedDial/SpeedDial.d.ts +2 -4
  256. package/SpeedDial/SpeedDial.js +3 -6
  257. package/SpeedDialAction/SpeedDialAction.d.ts +3 -3
  258. package/SpeedDialAction/SpeedDialAction.js +3 -3
  259. package/SpeedDialIcon/SpeedDialIcon.d.ts +2 -2
  260. package/SpeedDialIcon/SpeedDialIcon.js +3 -3
  261. package/Stack/Stack.d.ts +2 -2
  262. package/Step/Step.d.ts +2 -2
  263. package/Step/Step.js +3 -3
  264. package/StepButton/StepButton.d.ts +3 -3
  265. package/StepButton/StepButton.js +3 -3
  266. package/StepConnector/StepConnector.d.ts +3 -3
  267. package/StepConnector/StepConnector.js +3 -3
  268. package/StepContent/StepContent.d.ts +2 -2
  269. package/StepContent/StepContent.js +3 -3
  270. package/StepIcon/StepIcon.d.ts +2 -2
  271. package/StepIcon/StepIcon.js +3 -3
  272. package/StepLabel/StepLabel.d.ts +2 -4
  273. package/StepLabel/StepLabel.js +3 -7
  274. package/Stepper/Stepper.d.ts +2 -2
  275. package/Stepper/Stepper.js +7 -5
  276. package/Stepper/stepperClasses.d.ts +2 -0
  277. package/Stepper/stepperClasses.js +1 -1
  278. package/SvgIcon/SvgIcon.d.ts +3 -3
  279. package/SvgIcon/SvgIcon.js +3 -3
  280. package/SwipeableDrawer/SwipeableDrawer.d.ts +3 -3
  281. package/SwipeableDrawer/SwipeableDrawer.js +4 -4
  282. package/Switch/Switch.d.ts +4 -4
  283. package/Switch/Switch.js +3 -3
  284. package/Tab/Tab.d.ts +4 -4
  285. package/Tab/Tab.js +14 -10
  286. package/Tab/tabClasses.d.ts +5 -1
  287. package/Tab/tabClasses.js +1 -1
  288. package/TabScrollButton/TabScrollButton.d.ts +3 -3
  289. package/TabScrollButton/TabScrollButton.js +4 -4
  290. package/Table/Table.d.ts +2 -2
  291. package/Table/Table.js +3 -3
  292. package/TableBody/TableBody.d.ts +2 -2
  293. package/TableBody/TableBody.js +3 -3
  294. package/TableCell/TableCell.d.ts +2 -2
  295. package/TableCell/TableCell.js +3 -3
  296. package/TableContainer/TableContainer.d.ts +2 -2
  297. package/TableContainer/TableContainer.js +3 -3
  298. package/TableFooter/TableFooter.d.ts +2 -2
  299. package/TableFooter/TableFooter.js +3 -3
  300. package/TableHead/TableHead.d.ts +2 -2
  301. package/TableHead/TableHead.js +3 -3
  302. package/TablePagination/TablePagination.d.ts +4 -4
  303. package/TablePagination/TablePagination.js +4 -4
  304. package/TableRow/TableRow.d.ts +2 -2
  305. package/TableRow/TableRow.js +3 -3
  306. package/TableSortLabel/TableSortLabel.d.ts +3 -3
  307. package/TableSortLabel/TableSortLabel.js +4 -4
  308. package/TableSortLabel/tableSortLabelClasses.d.ts +10 -2
  309. package/TableSortLabel/tableSortLabelClasses.js +1 -1
  310. package/Tabs/Tabs.d.ts +3 -3
  311. package/Tabs/Tabs.js +6 -15
  312. package/TextField/TextField.d.ts +10 -10
  313. package/TextField/TextField.js +3 -3
  314. package/TextareaAutosize/TextareaAutosize.d.ts +14 -0
  315. package/TextareaAutosize/TextareaAutosize.js +222 -0
  316. package/TextareaAutosize/TextareaAutosize.types.d.ts +13 -0
  317. package/TextareaAutosize/TextareaAutosize.types.js +1 -0
  318. package/TextareaAutosize/index.d.ts +3 -2
  319. package/TextareaAutosize/index.js +1 -1
  320. package/ToggleButton/ToggleButton.d.ts +3 -3
  321. package/ToggleButton/ToggleButton.js +3 -3
  322. package/ToggleButtonGroup/ToggleButtonGroup.d.ts +2 -2
  323. package/ToggleButtonGroup/ToggleButtonGroup.js +3 -3
  324. package/Toolbar/Toolbar.d.ts +2 -2
  325. package/Toolbar/Toolbar.js +3 -3
  326. package/Tooltip/Tooltip.d.ts +2 -2
  327. package/Tooltip/Tooltip.js +8 -19
  328. package/Typography/Typography.d.ts +3 -3
  329. package/Typography/Typography.js +4 -4
  330. package/Unstable_TrapFocus/FocusTrap.d.ts +10 -0
  331. package/Unstable_TrapFocus/FocusTrap.js +330 -0
  332. package/Unstable_TrapFocus/FocusTrap.types.d.ts +51 -0
  333. package/Unstable_TrapFocus/FocusTrap.types.js +1 -0
  334. package/Unstable_TrapFocus/index.d.ts +2 -2
  335. package/Unstable_TrapFocus/index.js +1 -1
  336. package/Zoom/Zoom.d.ts +3 -3
  337. package/Zoom/Zoom.js +1 -1
  338. package/index.d.ts +1 -1
  339. package/index.js +2 -2
  340. package/modern/Accordion/Accordion.js +3 -5
  341. package/modern/AccordionActions/AccordionActions.js +3 -3
  342. package/modern/AccordionDetails/AccordionDetails.js +3 -3
  343. package/modern/AccordionSummary/AccordionSummary.js +3 -3
  344. package/modern/Alert/Alert.js +3 -3
  345. package/modern/AlertTitle/AlertTitle.js +3 -3
  346. package/modern/AppBar/AppBar.js +5 -9
  347. package/modern/Autocomplete/Autocomplete.js +14 -27
  348. package/modern/Avatar/Avatar.js +3 -4
  349. package/modern/AvatarGroup/AvatarGroup.js +3 -3
  350. package/modern/Backdrop/Backdrop.js +5 -8
  351. package/modern/Badge/Badge.js +5 -5
  352. package/modern/Badge/useBadge.js +41 -0
  353. package/modern/Badge/useBadge.types.js +1 -0
  354. package/modern/BottomNavigation/BottomNavigation.js +3 -3
  355. package/modern/BottomNavigationAction/BottomNavigationAction.js +3 -3
  356. package/modern/Breadcrumbs/Breadcrumbs.js +4 -4
  357. package/modern/Button/Button.js +3 -3
  358. package/modern/ButtonBase/ButtonBase.js +23 -52
  359. package/modern/ButtonBase/TouchRipple.js +3 -3
  360. package/modern/ButtonGroup/ButtonGroup.js +3 -3
  361. package/modern/Card/Card.js +3 -3
  362. package/modern/CardActionArea/CardActionArea.js +3 -3
  363. package/modern/CardActions/CardActions.js +3 -3
  364. package/modern/CardContent/CardContent.js +3 -3
  365. package/modern/CardHeader/CardHeader.js +3 -3
  366. package/modern/CardMedia/CardMedia.js +3 -3
  367. package/modern/Checkbox/Checkbox.js +3 -3
  368. package/modern/Chip/Chip.js +3 -5
  369. package/modern/CircularProgress/CircularProgress.js +3 -3
  370. package/modern/ClickAwayListener/ClickAwayListener.js +178 -0
  371. package/modern/ClickAwayListener/index.js +1 -1
  372. package/modern/Collapse/Collapse.js +3 -4
  373. package/modern/CssBaseline/CssBaseline.js +66 -8
  374. package/modern/DefaultPropsProvider/DefaultPropsProvider.js +29 -0
  375. package/modern/DefaultPropsProvider/index.js +1 -0
  376. package/modern/Dialog/Dialog.js +4 -7
  377. package/modern/DialogActions/DialogActions.js +3 -3
  378. package/modern/DialogContent/DialogContent.js +3 -3
  379. package/modern/DialogContentText/DialogContentText.js +3 -3
  380. package/modern/DialogTitle/DialogTitle.js +3 -3
  381. package/modern/Divider/Divider.js +3 -3
  382. package/modern/Drawer/Drawer.js +3 -4
  383. package/modern/Fab/Fab.js +3 -3
  384. package/modern/Fade/Fade.js +1 -1
  385. package/modern/FilledInput/FilledInput.js +13 -11
  386. package/modern/FilledInput/filledInputClasses.js +1 -1
  387. package/modern/FormControl/FormControl.js +3 -3
  388. package/modern/FormControlLabel/FormControlLabel.js +3 -3
  389. package/modern/FormGroup/FormGroup.js +3 -3
  390. package/modern/FormHelperText/FormHelperText.js +3 -3
  391. package/modern/FormLabel/FormLabel.js +3 -3
  392. package/modern/Grid/Grid.js +7 -13
  393. package/modern/Grow/Grow.js +1 -1
  394. package/modern/Icon/Icon.js +3 -3
  395. package/modern/IconButton/IconButton.js +3 -5
  396. package/modern/ImageList/ImageList.js +3 -11
  397. package/modern/ImageListItem/ImageListItem.js +3 -3
  398. package/modern/ImageListItemBar/ImageListItemBar.js +3 -3
  399. package/modern/InitColorSchemeScript/InitColorSchemeScript.js +16 -0
  400. package/modern/InitColorSchemeScript/index.js +1 -0
  401. package/modern/Input/Input.js +5 -9
  402. package/modern/InputAdornment/InputAdornment.js +3 -5
  403. package/modern/InputBase/InputBase.js +33 -42
  404. package/modern/InputLabel/InputLabel.js +3 -3
  405. package/modern/LinearProgress/LinearProgress.js +3 -3
  406. package/modern/Link/Link.js +7 -18
  407. package/modern/List/List.js +3 -3
  408. package/modern/ListItem/ListItem.js +4 -4
  409. package/modern/ListItemAvatar/ListItemAvatar.js +3 -3
  410. package/modern/ListItemButton/ListItemButton.js +3 -3
  411. package/modern/ListItemIcon/ListItemIcon.js +3 -3
  412. package/modern/ListItemSecondaryAction/ListItemSecondaryAction.js +3 -3
  413. package/modern/ListItemText/ListItemText.js +3 -3
  414. package/modern/ListSubheader/ListSubheader.js +3 -3
  415. package/modern/Menu/Menu.js +5 -8
  416. package/modern/MenuItem/MenuItem.js +3 -3
  417. package/modern/MobileStepper/MobileStepper.js +3 -3
  418. package/modern/Modal/Modal.js +33 -25
  419. package/modern/Modal/ModalManager.js +211 -0
  420. package/modern/Modal/index.js +1 -1
  421. package/modern/Modal/useModal.js +195 -0
  422. package/modern/Modal/useModal.types.js +1 -0
  423. package/modern/NativeSelect/NativeSelectInput.js +0 -4
  424. package/modern/NoSsr/NoSsr.js +73 -0
  425. package/modern/NoSsr/NoSsr.types.js +1 -0
  426. package/modern/NoSsr/index.js +1 -1
  427. package/modern/OutlinedInput/OutlinedInput.js +4 -5
  428. package/modern/Pagination/Pagination.js +3 -3
  429. package/modern/PaginationItem/PaginationItem.js +3 -3
  430. package/modern/Paper/Paper.js +3 -4
  431. package/modern/PigmentContainer/PigmentContainer.js +98 -0
  432. package/modern/PigmentContainer/index.js +3 -0
  433. package/modern/PigmentGrid/PigmentGrid.js +149 -0
  434. package/modern/PigmentGrid/index.js +3 -0
  435. package/modern/PigmentHidden/PigmentHidden.js +278 -0
  436. package/modern/PigmentHidden/index.js +2 -0
  437. package/modern/PigmentStack/PigmentStack.js +81 -0
  438. package/modern/PigmentStack/index.js +3 -0
  439. package/modern/Popover/Popover.js +30 -29
  440. package/modern/Popper/BasePopper.js +370 -0
  441. package/modern/Popper/BasePopper.types.js +1 -0
  442. package/modern/Popper/Popper.js +11 -10
  443. package/modern/Popper/index.js +2 -1
  444. package/modern/Popper/popperClasses.js +7 -0
  445. package/modern/Portal/Portal.js +92 -0
  446. package/modern/Portal/Portal.types.js +1 -0
  447. package/modern/Portal/index.js +1 -1
  448. package/modern/Radio/Radio.js +3 -3
  449. package/modern/Rating/Rating.js +8 -15
  450. package/modern/ScopedCssBaseline/ScopedCssBaseline.js +24 -11
  451. package/modern/Skeleton/Skeleton.js +3 -3
  452. package/modern/Slide/Slide.js +1 -1
  453. package/modern/Slider/Slider.js +6 -5
  454. package/modern/Slider/useSlider.js +647 -0
  455. package/modern/Slider/useSlider.types.js +1 -0
  456. package/modern/Snackbar/Snackbar.js +6 -7
  457. package/modern/Snackbar/useSnackbar.js +133 -0
  458. package/modern/Snackbar/useSnackbar.types.js +1 -0
  459. package/modern/SnackbarContent/SnackbarContent.js +3 -3
  460. package/modern/SpeedDial/SpeedDial.js +3 -6
  461. package/modern/SpeedDialAction/SpeedDialAction.js +3 -3
  462. package/modern/SpeedDialIcon/SpeedDialIcon.js +3 -3
  463. package/modern/Step/Step.js +3 -3
  464. package/modern/StepButton/StepButton.js +3 -3
  465. package/modern/StepConnector/StepConnector.js +3 -3
  466. package/modern/StepContent/StepContent.js +3 -3
  467. package/modern/StepIcon/StepIcon.js +3 -3
  468. package/modern/StepLabel/StepLabel.js +3 -7
  469. package/modern/Stepper/Stepper.js +7 -5
  470. package/modern/Stepper/stepperClasses.js +1 -1
  471. package/modern/SvgIcon/SvgIcon.js +3 -3
  472. package/modern/SwipeableDrawer/SwipeableDrawer.js +4 -4
  473. package/modern/Switch/Switch.js +3 -3
  474. package/modern/Tab/Tab.js +14 -10
  475. package/modern/Tab/tabClasses.js +1 -1
  476. package/modern/TabScrollButton/TabScrollButton.js +4 -4
  477. package/modern/Table/Table.js +3 -3
  478. package/modern/TableBody/TableBody.js +3 -3
  479. package/modern/TableCell/TableCell.js +3 -3
  480. package/modern/TableContainer/TableContainer.js +3 -3
  481. package/modern/TableFooter/TableFooter.js +3 -3
  482. package/modern/TableHead/TableHead.js +3 -3
  483. package/modern/TablePagination/TablePagination.js +4 -4
  484. package/modern/TableRow/TableRow.js +3 -3
  485. package/modern/TableSortLabel/TableSortLabel.js +4 -4
  486. package/modern/TableSortLabel/tableSortLabelClasses.js +1 -1
  487. package/modern/Tabs/Tabs.js +6 -15
  488. package/modern/TextField/TextField.js +3 -3
  489. package/modern/TextareaAutosize/TextareaAutosize.js +222 -0
  490. package/modern/TextareaAutosize/TextareaAutosize.types.js +1 -0
  491. package/modern/TextareaAutosize/index.js +1 -1
  492. package/modern/ToggleButton/ToggleButton.js +3 -3
  493. package/modern/ToggleButtonGroup/ToggleButtonGroup.js +3 -3
  494. package/modern/Toolbar/Toolbar.js +3 -3
  495. package/modern/Tooltip/Tooltip.js +8 -19
  496. package/modern/Typography/Typography.js +4 -4
  497. package/modern/Unstable_TrapFocus/FocusTrap.js +330 -0
  498. package/modern/Unstable_TrapFocus/FocusTrap.types.js +1 -0
  499. package/modern/Unstable_TrapFocus/index.js +1 -1
  500. package/modern/Zoom/Zoom.js +1 -1
  501. package/modern/index.js +2 -2
  502. package/modern/styles/CssVarsProvider.js +19 -7
  503. package/modern/styles/createTheme.js +1 -1
  504. package/modern/styles/createTransitions.js +2 -2
  505. package/modern/styles/extendTheme.js +3 -0
  506. package/modern/styles/index.js +1 -1
  507. package/modern/styles/stringifyTheme.js +55 -0
  508. package/modern/useAutocomplete/useAutocomplete.js +976 -2
  509. package/modern/useLazyRipple/index.js +3 -0
  510. package/modern/useLazyRipple/useLazyRipple.js +85 -0
  511. package/modern/usePagination/usePagination.js +1 -1
  512. package/modern/utils/PolymorphicComponent.js +1 -0
  513. package/modern/utils/areArraysEqual.js +4 -0
  514. package/modern/utils/index.js +1 -2
  515. package/modern/utils/isHostComponent.js +7 -0
  516. package/modern/utils/omitEventHandlers.js +18 -0
  517. package/modern/utils/shouldSpreadAdditionalProps.js +1 -1
  518. package/modern/utils/useSlot.js +3 -1
  519. package/modern/zero-styled/index.js +24 -5
  520. package/node/Accordion/Accordion.js +2 -4
  521. package/node/AccordionActions/AccordionActions.js +2 -2
  522. package/node/AccordionDetails/AccordionDetails.js +2 -2
  523. package/node/AccordionSummary/AccordionSummary.js +2 -2
  524. package/node/Alert/Alert.js +2 -2
  525. package/node/AlertTitle/AlertTitle.js +2 -2
  526. package/node/AppBar/AppBar.js +4 -8
  527. package/node/Autocomplete/Autocomplete.js +15 -28
  528. package/node/Avatar/Avatar.js +2 -3
  529. package/node/AvatarGroup/AvatarGroup.js +2 -2
  530. package/node/Backdrop/Backdrop.js +4 -7
  531. package/node/Badge/Badge.js +7 -7
  532. package/node/Badge/useBadge.js +46 -0
  533. package/node/Badge/useBadge.types.js +5 -0
  534. package/node/BottomNavigation/BottomNavigation.js +2 -2
  535. package/node/BottomNavigationAction/BottomNavigationAction.js +2 -2
  536. package/node/Breadcrumbs/Breadcrumbs.js +4 -4
  537. package/node/Button/Button.js +2 -2
  538. package/node/ButtonBase/ButtonBase.js +22 -51
  539. package/node/ButtonBase/TouchRipple.js +2 -2
  540. package/node/ButtonGroup/ButtonGroup.js +2 -2
  541. package/node/Card/Card.js +2 -2
  542. package/node/CardActionArea/CardActionArea.js +2 -2
  543. package/node/CardActions/CardActions.js +2 -2
  544. package/node/CardContent/CardContent.js +2 -2
  545. package/node/CardHeader/CardHeader.js +2 -2
  546. package/node/CardMedia/CardMedia.js +2 -2
  547. package/node/Checkbox/Checkbox.js +2 -2
  548. package/node/Chip/Chip.js +2 -4
  549. package/node/CircularProgress/CircularProgress.js +2 -2
  550. package/node/ClickAwayListener/ClickAwayListener.js +184 -0
  551. package/node/ClickAwayListener/index.js +1 -1
  552. package/node/Collapse/Collapse.js +3 -4
  553. package/node/CssBaseline/CssBaseline.js +70 -10
  554. package/node/DefaultPropsProvider/DefaultPropsProvider.js +38 -0
  555. package/node/DefaultPropsProvider/index.js +20 -0
  556. package/node/Dialog/Dialog.js +4 -7
  557. package/node/DialogActions/DialogActions.js +2 -2
  558. package/node/DialogContent/DialogContent.js +2 -2
  559. package/node/DialogContentText/DialogContentText.js +2 -2
  560. package/node/DialogTitle/DialogTitle.js +2 -2
  561. package/node/Divider/Divider.js +2 -2
  562. package/node/Drawer/Drawer.js +3 -4
  563. package/node/Fab/Fab.js +2 -2
  564. package/node/Fade/Fade.js +2 -2
  565. package/node/FilledInput/FilledInput.js +12 -10
  566. package/node/FilledInput/filledInputClasses.js +1 -1
  567. package/node/FormControl/FormControl.js +2 -2
  568. package/node/FormControlLabel/FormControlLabel.js +2 -2
  569. package/node/FormGroup/FormGroup.js +2 -2
  570. package/node/FormHelperText/FormHelperText.js +2 -2
  571. package/node/FormLabel/FormLabel.js +2 -2
  572. package/node/Grid/Grid.js +7 -13
  573. package/node/Grow/Grow.js +2 -2
  574. package/node/Icon/Icon.js +2 -2
  575. package/node/IconButton/IconButton.js +2 -4
  576. package/node/ImageList/ImageList.js +2 -10
  577. package/node/ImageListItem/ImageListItem.js +2 -2
  578. package/node/ImageListItemBar/ImageListItemBar.js +2 -2
  579. package/node/InitColorSchemeScript/InitColorSchemeScript.js +25 -0
  580. package/node/InitColorSchemeScript/index.js +13 -0
  581. package/node/Input/Input.js +4 -8
  582. package/node/InputAdornment/InputAdornment.js +2 -4
  583. package/node/InputBase/InputBase.js +37 -46
  584. package/node/InputLabel/InputLabel.js +2 -2
  585. package/node/LinearProgress/LinearProgress.js +2 -2
  586. package/node/Link/Link.js +7 -18
  587. package/node/List/List.js +2 -2
  588. package/node/ListItem/ListItem.js +5 -5
  589. package/node/ListItemAvatar/ListItemAvatar.js +2 -2
  590. package/node/ListItemButton/ListItemButton.js +2 -2
  591. package/node/ListItemIcon/ListItemIcon.js +2 -2
  592. package/node/ListItemSecondaryAction/ListItemSecondaryAction.js +2 -2
  593. package/node/ListItemText/ListItemText.js +2 -2
  594. package/node/ListSubheader/ListSubheader.js +2 -2
  595. package/node/Menu/Menu.js +6 -9
  596. package/node/MenuItem/MenuItem.js +2 -2
  597. package/node/MobileStepper/MobileStepper.js +2 -2
  598. package/node/Modal/Modal.js +33 -26
  599. package/node/Modal/ModalManager.js +219 -0
  600. package/node/Modal/index.js +2 -2
  601. package/node/Modal/useModal.js +205 -0
  602. package/node/Modal/useModal.types.js +5 -0
  603. package/node/NativeSelect/NativeSelectInput.js +0 -4
  604. package/node/NoSsr/NoSsr.js +81 -0
  605. package/node/NoSsr/NoSsr.types.js +5 -0
  606. package/node/NoSsr/index.js +3 -2
  607. package/node/OutlinedInput/OutlinedInput.js +3 -4
  608. package/node/Pagination/Pagination.js +2 -2
  609. package/node/PaginationItem/PaginationItem.js +2 -2
  610. package/node/Paper/Paper.js +3 -4
  611. package/node/PigmentContainer/PigmentContainer.js +108 -0
  612. package/node/PigmentContainer/index.js +36 -0
  613. package/node/PigmentGrid/PigmentGrid.js +159 -0
  614. package/node/PigmentGrid/index.js +36 -0
  615. package/node/PigmentHidden/PigmentHidden.js +287 -0
  616. package/node/PigmentHidden/index.js +26 -0
  617. package/node/PigmentStack/PigmentStack.js +91 -0
  618. package/node/PigmentStack/index.js +36 -0
  619. package/node/Popover/Popover.js +31 -30
  620. package/node/Popper/BasePopper.js +379 -0
  621. package/node/Popper/BasePopper.types.js +5 -0
  622. package/node/Popper/Popper.js +12 -11
  623. package/node/Popper/index.js +14 -1
  624. package/node/Popper/popperClasses.js +15 -0
  625. package/node/Portal/Portal.js +100 -0
  626. package/node/Portal/Portal.types.js +5 -0
  627. package/node/Portal/index.js +3 -2
  628. package/node/Radio/Radio.js +2 -2
  629. package/node/Rating/Rating.js +6 -13
  630. package/node/ScopedCssBaseline/ScopedCssBaseline.js +27 -13
  631. package/node/Skeleton/Skeleton.js +2 -2
  632. package/node/Slide/Slide.js +2 -2
  633. package/node/Slider/Slider.js +16 -15
  634. package/node/Slider/useSlider.js +670 -0
  635. package/node/Slider/useSlider.types.js +5 -0
  636. package/node/Snackbar/Snackbar.js +9 -10
  637. package/node/Snackbar/useSnackbar.js +141 -0
  638. package/node/Snackbar/useSnackbar.types.js +5 -0
  639. package/node/SnackbarContent/SnackbarContent.js +2 -2
  640. package/node/SpeedDial/SpeedDial.js +3 -6
  641. package/node/SpeedDialAction/SpeedDialAction.js +2 -2
  642. package/node/SpeedDialIcon/SpeedDialIcon.js +2 -2
  643. package/node/Step/Step.js +2 -2
  644. package/node/StepButton/StepButton.js +2 -2
  645. package/node/StepConnector/StepConnector.js +2 -2
  646. package/node/StepContent/StepContent.js +2 -2
  647. package/node/StepIcon/StepIcon.js +2 -2
  648. package/node/StepLabel/StepLabel.js +2 -6
  649. package/node/Stepper/Stepper.js +6 -4
  650. package/node/Stepper/stepperClasses.js +1 -1
  651. package/node/SvgIcon/SvgIcon.js +2 -2
  652. package/node/SwipeableDrawer/SwipeableDrawer.js +6 -6
  653. package/node/Switch/Switch.js +2 -2
  654. package/node/Tab/Tab.js +13 -9
  655. package/node/Tab/tabClasses.js +1 -1
  656. package/node/TabScrollButton/TabScrollButton.js +5 -5
  657. package/node/Table/Table.js +2 -2
  658. package/node/TableBody/TableBody.js +2 -2
  659. package/node/TableCell/TableCell.js +2 -2
  660. package/node/TableContainer/TableContainer.js +2 -2
  661. package/node/TableFooter/TableFooter.js +2 -2
  662. package/node/TableHead/TableHead.js +2 -2
  663. package/node/TablePagination/TablePagination.js +4 -4
  664. package/node/TableRow/TableRow.js +2 -2
  665. package/node/TableSortLabel/TableSortLabel.js +3 -3
  666. package/node/TableSortLabel/tableSortLabelClasses.js +1 -1
  667. package/node/Tabs/Tabs.js +8 -17
  668. package/node/TextField/TextField.js +2 -2
  669. package/node/TextareaAutosize/TextareaAutosize.js +230 -0
  670. package/node/TextareaAutosize/TextareaAutosize.types.js +5 -0
  671. package/node/TextareaAutosize/index.js +3 -2
  672. package/node/ToggleButton/ToggleButton.js +2 -2
  673. package/node/ToggleButtonGroup/ToggleButtonGroup.js +2 -2
  674. package/node/Toolbar/Toolbar.js +2 -2
  675. package/node/Tooltip/Tooltip.js +12 -23
  676. package/node/Typography/Typography.js +4 -4
  677. package/node/Unstable_TrapFocus/FocusTrap.js +339 -0
  678. package/node/Unstable_TrapFocus/FocusTrap.types.js +5 -0
  679. package/node/Unstable_TrapFocus/index.js +3 -2
  680. package/node/Zoom/Zoom.js +2 -2
  681. package/node/index.js +3 -3
  682. package/node/styles/CssVarsProvider.js +20 -8
  683. package/node/styles/createTheme.js +1 -1
  684. package/node/styles/createTransitions.js +2 -2
  685. package/node/styles/extendTheme.js +3 -0
  686. package/node/styles/index.js +8 -1
  687. package/node/styles/stringifyTheme.js +62 -0
  688. package/node/useAutocomplete/useAutocomplete.js +985 -18
  689. package/node/{useTouchRipple → useLazyRipple}/index.js +2 -2
  690. package/node/useLazyRipple/useLazyRipple.js +104 -0
  691. package/node/usePagination/usePagination.js +1 -1
  692. package/node/utils/PolymorphicComponent.js +5 -0
  693. package/node/utils/areArraysEqual.js +10 -0
  694. package/node/utils/index.js +2 -9
  695. package/node/utils/isHostComponent.js +13 -0
  696. package/node/utils/omitEventHandlers.js +24 -0
  697. package/node/utils/shouldSpreadAdditionalProps.js +3 -2
  698. package/node/utils/useSlot.js +6 -4
  699. package/node/zero-styled/index.js +33 -5
  700. package/package.json +23 -8
  701. package/styles/CssVarsProvider.d.ts +3 -2
  702. package/styles/CssVarsProvider.js +19 -7
  703. package/styles/createTheme.js +1 -1
  704. package/styles/createTransitions.js +2 -2
  705. package/styles/extendTheme.js +3 -0
  706. package/styles/index.d.ts +1 -0
  707. package/styles/index.js +1 -1
  708. package/styles/overrides.d.ts +1 -1
  709. package/styles/responsiveFontSizes.d.ts +3 -4
  710. package/styles/stringifyTheme.d.ts +20 -0
  711. package/styles/stringifyTheme.js +55 -0
  712. package/useAutocomplete/useAutocomplete.d.ts +468 -2
  713. package/useAutocomplete/useAutocomplete.js +976 -2
  714. package/useLazyRipple/index.d.ts +1 -0
  715. package/useLazyRipple/index.js +3 -0
  716. package/useLazyRipple/package.json +6 -0
  717. package/useLazyRipple/useLazyRipple.d.ts +32 -0
  718. package/useLazyRipple/useLazyRipple.js +85 -0
  719. package/usePagination/usePagination.js +1 -1
  720. package/utils/PolymorphicComponent.d.ts +17 -0
  721. package/utils/PolymorphicComponent.js +1 -0
  722. package/utils/areArraysEqual.d.ts +3 -0
  723. package/utils/areArraysEqual.js +4 -0
  724. package/utils/index.d.ts +2 -2
  725. package/utils/index.js +1 -2
  726. package/utils/isHostComponent.d.ts +6 -0
  727. package/utils/isHostComponent.js +7 -0
  728. package/utils/omitEventHandlers.d.ts +9 -0
  729. package/utils/omitEventHandlers.js +18 -0
  730. package/utils/shouldSpreadAdditionalProps.js +1 -1
  731. package/utils/types.d.ts +2 -1
  732. package/utils/useSlot.js +3 -1
  733. package/zero-styled/index.d.ts +10 -2
  734. package/zero-styled/index.js +24 -5
  735. package/modern/useMediaQuery/useMediaQueryTheme.js +0 -8
  736. package/modern/useTouchRipple/index.js +0 -3
  737. package/modern/useTouchRipple/useTouchRipple.js +0 -94
  738. package/modern/utils/scrollLeft.js +0 -1
  739. package/modern/utils/useIsFocusVisible.js +0 -4
  740. package/node/useMediaQuery/useMediaQueryTheme.js +0 -13
  741. package/node/useTouchRipple/useTouchRipple.js +0 -105
  742. package/node/utils/scrollLeft.js +0 -18
  743. package/node/utils/useIsFocusVisible.js +0 -10
  744. package/useMediaQuery/useMediaQueryTheme.d.ts +0 -3
  745. package/useMediaQuery/useMediaQueryTheme.js +0 -8
  746. package/useTouchRipple/index.d.ts +0 -1
  747. package/useTouchRipple/index.js +0 -3
  748. package/useTouchRipple/useTouchRipple.d.ts +0 -28
  749. package/useTouchRipple/useTouchRipple.js +0 -94
  750. package/utils/scrollLeft.js +0 -1
  751. package/utils/useIsFocusVisible.d.ts +0 -3
  752. package/utils/useIsFocusVisible.js +0 -4
@@ -0,0 +1,3 @@
1
+ export { default } from './PigmentStack';
2
+ export * from './PigmentStack';
3
+ export { default as stackClasses } from '../Stack/stackClasses';
@@ -3,14 +3,15 @@
3
3
  import * as React from 'react';
4
4
  import PropTypes from 'prop-types';
5
5
  import clsx from 'clsx';
6
- import { useSlotProps, isHostComponent } from '@mui/base/utils';
7
6
  import composeClasses from '@mui/utils/composeClasses';
8
7
  import HTMLElementType from '@mui/utils/HTMLElementType';
9
8
  import refType from '@mui/utils/refType';
10
9
  import elementTypeAcceptingRef from '@mui/utils/elementTypeAcceptingRef';
11
10
  import integerPropType from '@mui/utils/integerPropType';
12
11
  import chainPropTypes from '@mui/utils/chainPropTypes';
13
- import { styled, createUseThemeProps } from '../zero-styled';
12
+ import isHostComponent from '../utils/isHostComponent';
13
+ import { styled } from '../zero-styled';
14
+ import { useDefaultProps } from '../DefaultPropsProvider';
14
15
  import debounce from '../utils/debounce';
15
16
  import ownerDocument from '../utils/ownerDocument';
16
17
  import ownerWindow from '../utils/ownerWindow';
@@ -19,8 +20,8 @@ import Grow from '../Grow';
19
20
  import Modal from '../Modal';
20
21
  import PaperBase from '../Paper';
21
22
  import { getPopoverUtilityClass } from './popoverClasses';
23
+ import useSlot from '../utils/useSlot';
22
24
  import { jsx as _jsx } from "react/jsx-runtime";
23
- const useThemeProps = createUseThemeProps('MuiPopover');
24
25
  export function getOffsetTop(rect, vertical) {
25
26
  let offset = 0;
26
27
  if (typeof vertical === 'number') {
@@ -82,7 +83,7 @@ export const PopoverPaper = styled(PaperBase, {
82
83
  outline: 0
83
84
  });
84
85
  const Popover = /*#__PURE__*/React.forwardRef(function Popover(inProps, ref) {
85
- const props = useThemeProps({
86
+ const props = useDefaultProps({
86
87
  props: inProps,
87
88
  name: 'MuiPopover'
88
89
  });
@@ -102,8 +103,8 @@ const Popover = /*#__PURE__*/React.forwardRef(function Popover(inProps, ref) {
102
103
  marginThreshold = 16,
103
104
  open,
104
105
  PaperProps: PaperPropsProp = {},
105
- slots,
106
- slotProps,
106
+ slots = {},
107
+ slotProps = {},
107
108
  transformOrigin = {
108
109
  vertical: 'top',
109
110
  horizontal: 'left'
@@ -119,7 +120,6 @@ const Popover = /*#__PURE__*/React.forwardRef(function Popover(inProps, ref) {
119
120
  } = props;
120
121
  const externalPaperSlotProps = slotProps?.paper ?? PaperPropsProp;
121
122
  const paperRef = React.useRef();
122
- const handlePaperRef = useForkRef(paperRef, externalPaperSlotProps.ref);
123
123
  const ownerState = {
124
124
  ...props,
125
125
  anchorOrigin,
@@ -297,33 +297,33 @@ const Popover = /*#__PURE__*/React.forwardRef(function Popover(inProps, ref) {
297
297
  // If the anchorEl prop is provided, use its parent body element as the container
298
298
  // If neither are provided let the Modal take care of choosing the container
299
299
  const container = containerProp || (anchorEl ? ownerDocument(resolveAnchorEl(anchorEl)).body : undefined);
300
- const RootSlot = slots?.root ?? PopoverRoot;
301
- const PaperSlot = slots?.paper ?? PopoverPaper;
302
- const paperProps = useSlotProps({
303
- elementType: PaperSlot,
304
- externalSlotProps: {
305
- ...externalPaperSlotProps,
300
+ const externalForwardedProps = {
301
+ slots,
302
+ slotProps: {
303
+ ...slotProps,
304
+ paper: externalPaperSlotProps
305
+ }
306
+ };
307
+ const [PaperSlot, paperProps] = useSlot('paper', {
308
+ elementType: PopoverPaper,
309
+ externalForwardedProps,
310
+ additionalProps: {
311
+ elevation,
312
+ className: clsx(classes.paper, externalPaperSlotProps?.className),
306
313
  style: isPositioned ? externalPaperSlotProps.style : {
307
314
  ...externalPaperSlotProps.style,
308
315
  opacity: 0
309
316
  }
310
317
  },
311
- additionalProps: {
312
- elevation,
313
- ref: handlePaperRef
314
- },
315
- ownerState,
316
- className: clsx(classes.paper, externalPaperSlotProps?.className)
318
+ ownerState
317
319
  });
318
- const {
320
+ const [RootSlot, {
319
321
  slotProps: rootSlotPropsProp,
320
322
  ...rootProps
321
- } = useSlotProps({
322
- elementType: RootSlot,
323
- externalSlotProps: slotProps?.root || {},
324
- externalForwardedProps: other,
323
+ }] = useSlot('root', {
324
+ elementType: PopoverRoot,
325
+ externalForwardedProps,
325
326
  additionalProps: {
326
- ref,
327
327
  slotProps: {
328
328
  backdrop: {
329
329
  invisible: true
@@ -335,12 +335,15 @@ const Popover = /*#__PURE__*/React.forwardRef(function Popover(inProps, ref) {
335
335
  ownerState,
336
336
  className: clsx(classes.root, className)
337
337
  });
338
+ const handlePaperRef = useForkRef(paperRef, paperProps.ref);
338
339
  return /*#__PURE__*/_jsx(RootSlot, {
339
340
  ...rootProps,
340
341
  ...(!isHostComponent(RootSlot) && {
341
342
  slotProps: rootSlotPropsProp,
342
343
  disableScrollLock
343
344
  }),
345
+ ...other,
346
+ ref: ref,
344
347
  children: /*#__PURE__*/_jsx(TransitionComponent, {
345
348
  appear: true,
346
349
  in: open,
@@ -350,6 +353,7 @@ const Popover = /*#__PURE__*/React.forwardRef(function Popover(inProps, ref) {
350
353
  ...TransitionProps,
351
354
  children: /*#__PURE__*/_jsx(PaperSlot, {
352
355
  ...paperProps,
356
+ ref: handlePaperRef,
353
357
  children: children
354
358
  })
355
359
  })
@@ -472,9 +476,7 @@ process.env.NODE_ENV !== "production" ? Popover.propTypes /* remove-proptypes */
472
476
  component: elementTypeAcceptingRef
473
477
  }),
474
478
  /**
475
- * The extra props for the slot components.
476
- * You can override the existing props or add new ones.
477
- *
479
+ * The props used for each slot inside.
478
480
  * @default {}
479
481
  */
480
482
  slotProps: PropTypes.shape({
@@ -483,7 +485,6 @@ process.env.NODE_ENV !== "production" ? Popover.propTypes /* remove-proptypes */
483
485
  }),
484
486
  /**
485
487
  * The components used for each slot inside.
486
- *
487
488
  * @default {}
488
489
  */
489
490
  slots: PropTypes.shape({
@@ -0,0 +1,370 @@
1
+ 'use client';
2
+
3
+ import * as React from 'react';
4
+ import { chainPropTypes, HTMLElementType, refType, unstable_ownerDocument as ownerDocument, unstable_useEnhancedEffect as useEnhancedEffect, unstable_useForkRef as useForkRef } from '@mui/utils';
5
+ import { createPopper } from '@popperjs/core';
6
+ import PropTypes from 'prop-types';
7
+ import composeClasses from '@mui/utils/composeClasses';
8
+ import useSlotProps from '@mui/utils/useSlotProps';
9
+ import Portal from '../Portal';
10
+ import { getPopperUtilityClass } from './popperClasses';
11
+ import { jsx as _jsx } from "react/jsx-runtime";
12
+ function flipPlacement(placement, direction) {
13
+ if (direction === 'ltr') {
14
+ return placement;
15
+ }
16
+ switch (placement) {
17
+ case 'bottom-end':
18
+ return 'bottom-start';
19
+ case 'bottom-start':
20
+ return 'bottom-end';
21
+ case 'top-end':
22
+ return 'top-start';
23
+ case 'top-start':
24
+ return 'top-end';
25
+ default:
26
+ return placement;
27
+ }
28
+ }
29
+ function resolveAnchorEl(anchorEl) {
30
+ return typeof anchorEl === 'function' ? anchorEl() : anchorEl;
31
+ }
32
+ function isHTMLElement(element) {
33
+ return element.nodeType !== undefined;
34
+ }
35
+ function isVirtualElement(element) {
36
+ return !isHTMLElement(element);
37
+ }
38
+ const useUtilityClasses = ownerState => {
39
+ const {
40
+ classes
41
+ } = ownerState;
42
+ const slots = {
43
+ root: ['root']
44
+ };
45
+ return composeClasses(slots, getPopperUtilityClass, classes);
46
+ };
47
+ const defaultPopperOptions = {};
48
+ const PopperTooltip = /*#__PURE__*/React.forwardRef(function PopperTooltip(props, forwardedRef) {
49
+ const {
50
+ anchorEl,
51
+ children,
52
+ direction,
53
+ disablePortal,
54
+ modifiers,
55
+ open,
56
+ placement: initialPlacement,
57
+ popperOptions,
58
+ popperRef: popperRefProp,
59
+ slotProps = {},
60
+ slots = {},
61
+ TransitionProps,
62
+ // @ts-ignore internal logic
63
+ ownerState: ownerStateProp,
64
+ // prevent from spreading to DOM, it can come from the parent component e.g. Select.
65
+ ...other
66
+ } = props;
67
+ const tooltipRef = React.useRef(null);
68
+ const ownRef = useForkRef(tooltipRef, forwardedRef);
69
+ const popperRef = React.useRef(null);
70
+ const handlePopperRef = useForkRef(popperRef, popperRefProp);
71
+ const handlePopperRefRef = React.useRef(handlePopperRef);
72
+ useEnhancedEffect(() => {
73
+ handlePopperRefRef.current = handlePopperRef;
74
+ }, [handlePopperRef]);
75
+ React.useImperativeHandle(popperRefProp, () => popperRef.current, []);
76
+ const rtlPlacement = flipPlacement(initialPlacement, direction);
77
+ /**
78
+ * placement initialized from prop but can change during lifetime if modifiers.flip.
79
+ * modifiers.flip is essentially a flip for controlled/uncontrolled behavior
80
+ */
81
+ const [placement, setPlacement] = React.useState(rtlPlacement);
82
+ const [resolvedAnchorElement, setResolvedAnchorElement] = React.useState(resolveAnchorEl(anchorEl));
83
+ React.useEffect(() => {
84
+ if (popperRef.current) {
85
+ popperRef.current.forceUpdate();
86
+ }
87
+ });
88
+ React.useEffect(() => {
89
+ if (anchorEl) {
90
+ setResolvedAnchorElement(resolveAnchorEl(anchorEl));
91
+ }
92
+ }, [anchorEl]);
93
+ useEnhancedEffect(() => {
94
+ if (!resolvedAnchorElement || !open) {
95
+ return undefined;
96
+ }
97
+ const handlePopperUpdate = data => {
98
+ setPlacement(data.placement);
99
+ };
100
+ if (process.env.NODE_ENV !== 'production') {
101
+ if (resolvedAnchorElement && isHTMLElement(resolvedAnchorElement) && resolvedAnchorElement.nodeType === 1) {
102
+ const box = resolvedAnchorElement.getBoundingClientRect();
103
+ if (process.env.NODE_ENV !== 'test' && box.top === 0 && box.left === 0 && box.right === 0 && box.bottom === 0) {
104
+ console.warn(['MUI: The `anchorEl` prop provided to the component is invalid.', 'The anchor element should be part of the document layout.', "Make sure the element is present in the document or that it's not display none."].join('\n'));
105
+ }
106
+ }
107
+ }
108
+ let popperModifiers = [{
109
+ name: 'preventOverflow',
110
+ options: {
111
+ altBoundary: disablePortal
112
+ }
113
+ }, {
114
+ name: 'flip',
115
+ options: {
116
+ altBoundary: disablePortal
117
+ }
118
+ }, {
119
+ name: 'onUpdate',
120
+ enabled: true,
121
+ phase: 'afterWrite',
122
+ fn: ({
123
+ state
124
+ }) => {
125
+ handlePopperUpdate(state);
126
+ }
127
+ }];
128
+ if (modifiers != null) {
129
+ popperModifiers = popperModifiers.concat(modifiers);
130
+ }
131
+ if (popperOptions && popperOptions.modifiers != null) {
132
+ popperModifiers = popperModifiers.concat(popperOptions.modifiers);
133
+ }
134
+ const popper = createPopper(resolvedAnchorElement, tooltipRef.current, {
135
+ placement: rtlPlacement,
136
+ ...popperOptions,
137
+ modifiers: popperModifiers
138
+ });
139
+ handlePopperRefRef.current(popper);
140
+ return () => {
141
+ popper.destroy();
142
+ handlePopperRefRef.current(null);
143
+ };
144
+ }, [resolvedAnchorElement, disablePortal, modifiers, open, popperOptions, rtlPlacement]);
145
+ const childProps = {
146
+ placement: placement
147
+ };
148
+ if (TransitionProps !== null) {
149
+ childProps.TransitionProps = TransitionProps;
150
+ }
151
+ const classes = useUtilityClasses(props);
152
+ const Root = slots.root ?? 'div';
153
+ const rootProps = useSlotProps({
154
+ elementType: Root,
155
+ externalSlotProps: slotProps.root,
156
+ externalForwardedProps: other,
157
+ additionalProps: {
158
+ role: 'tooltip',
159
+ ref: ownRef
160
+ },
161
+ ownerState: props,
162
+ className: classes.root
163
+ });
164
+ return /*#__PURE__*/_jsx(Root, {
165
+ ...rootProps,
166
+ children: typeof children === 'function' ? children(childProps) : children
167
+ });
168
+ });
169
+
170
+ /**
171
+ * @ignore - internal component.
172
+ */
173
+ const Popper = /*#__PURE__*/React.forwardRef(function Popper(props, forwardedRef) {
174
+ const {
175
+ anchorEl,
176
+ children,
177
+ container: containerProp,
178
+ direction = 'ltr',
179
+ disablePortal = false,
180
+ keepMounted = false,
181
+ modifiers,
182
+ open,
183
+ placement = 'bottom',
184
+ popperOptions = defaultPopperOptions,
185
+ popperRef,
186
+ style,
187
+ transition = false,
188
+ slotProps = {},
189
+ slots = {},
190
+ ...other
191
+ } = props;
192
+ const [exited, setExited] = React.useState(true);
193
+ const handleEnter = () => {
194
+ setExited(false);
195
+ };
196
+ const handleExited = () => {
197
+ setExited(true);
198
+ };
199
+ if (!keepMounted && !open && (!transition || exited)) {
200
+ return null;
201
+ }
202
+
203
+ // If the container prop is provided, use that
204
+ // If the anchorEl prop is provided, use its parent body element as the container
205
+ // If neither are provided let the Modal take care of choosing the container
206
+ let container;
207
+ if (containerProp) {
208
+ container = containerProp;
209
+ } else if (anchorEl) {
210
+ const resolvedAnchorEl = resolveAnchorEl(anchorEl);
211
+ container = resolvedAnchorEl && isHTMLElement(resolvedAnchorEl) ? ownerDocument(resolvedAnchorEl).body : ownerDocument(null).body;
212
+ }
213
+ const display = !open && keepMounted && (!transition || exited) ? 'none' : undefined;
214
+ const transitionProps = transition ? {
215
+ in: open,
216
+ onEnter: handleEnter,
217
+ onExited: handleExited
218
+ } : undefined;
219
+ return /*#__PURE__*/_jsx(Portal, {
220
+ disablePortal: disablePortal,
221
+ container: container,
222
+ children: /*#__PURE__*/_jsx(PopperTooltip, {
223
+ anchorEl: anchorEl,
224
+ direction: direction,
225
+ disablePortal: disablePortal,
226
+ modifiers: modifiers,
227
+ ref: forwardedRef,
228
+ open: transition ? !exited : open,
229
+ placement: placement,
230
+ popperOptions: popperOptions,
231
+ popperRef: popperRef,
232
+ slotProps: slotProps,
233
+ slots: slots,
234
+ ...other,
235
+ style: {
236
+ // Prevents scroll issue, waiting for Popper.js to add this style once initiated.
237
+ position: 'fixed',
238
+ // Fix Popper.js display issue
239
+ top: 0,
240
+ left: 0,
241
+ display,
242
+ ...style
243
+ },
244
+ TransitionProps: transitionProps,
245
+ children: children
246
+ })
247
+ });
248
+ });
249
+ process.env.NODE_ENV !== "production" ? Popper.propTypes /* remove-proptypes */ = {
250
+ // ┌────────────────────────────── Warning ──────────────────────────────┐
251
+ // │ These PropTypes are generated from the TypeScript type definitions. │
252
+ // │ To update them, edit the TypeScript types and run `pnpm proptypes`. │
253
+ // └─────────────────────────────────────────────────────────────────────┘
254
+ /**
255
+ * An HTML element, [virtualElement](https://popper.js.org/docs/v2/virtual-elements/),
256
+ * or a function that returns either.
257
+ * It's used to set the position of the popper.
258
+ * The return value will passed as the reference object of the Popper instance.
259
+ */
260
+ anchorEl: chainPropTypes(PropTypes.oneOfType([HTMLElementType, PropTypes.object, PropTypes.func]), props => {
261
+ if (props.open) {
262
+ const resolvedAnchorEl = resolveAnchorEl(props.anchorEl);
263
+ if (resolvedAnchorEl && isHTMLElement(resolvedAnchorEl) && resolvedAnchorEl.nodeType === 1) {
264
+ const box = resolvedAnchorEl.getBoundingClientRect();
265
+ if (process.env.NODE_ENV !== 'test' && box.top === 0 && box.left === 0 && box.right === 0 && box.bottom === 0) {
266
+ return new Error(['MUI: The `anchorEl` prop provided to the component is invalid.', 'The anchor element should be part of the document layout.', "Make sure the element is present in the document or that it's not display none."].join('\n'));
267
+ }
268
+ } else if (!resolvedAnchorEl || typeof resolvedAnchorEl.getBoundingClientRect !== 'function' || isVirtualElement(resolvedAnchorEl) && resolvedAnchorEl.contextElement != null && resolvedAnchorEl.contextElement.nodeType !== 1) {
269
+ return new Error(['MUI: The `anchorEl` prop provided to the component is invalid.', 'It should be an HTML element instance or a virtualElement ', '(https://popper.js.org/docs/v2/virtual-elements/).'].join('\n'));
270
+ }
271
+ }
272
+ return null;
273
+ }),
274
+ /**
275
+ * Popper render function or node.
276
+ */
277
+ children: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.node, PropTypes.func]),
278
+ /**
279
+ * An HTML element or function that returns one.
280
+ * The `container` will have the portal children appended to it.
281
+ *
282
+ * You can also provide a callback, which is called in a React layout effect.
283
+ * This lets you set the container from a ref, and also makes server-side rendering possible.
284
+ *
285
+ * By default, it uses the body of the top-level document object,
286
+ * so it's simply `document.body` most of the time.
287
+ */
288
+ container: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([HTMLElementType, PropTypes.func]),
289
+ /**
290
+ * Direction of the text.
291
+ * @default 'ltr'
292
+ */
293
+ direction: PropTypes.oneOf(['ltr', 'rtl']),
294
+ /**
295
+ * The `children` will be under the DOM hierarchy of the parent component.
296
+ * @default false
297
+ */
298
+ disablePortal: PropTypes.bool,
299
+ /**
300
+ * Always keep the children in the DOM.
301
+ * This prop can be useful in SEO situation or
302
+ * when you want to maximize the responsiveness of the Popper.
303
+ * @default false
304
+ */
305
+ keepMounted: PropTypes.bool,
306
+ /**
307
+ * Popper.js is based on a "plugin-like" architecture,
308
+ * most of its features are fully encapsulated "modifiers".
309
+ *
310
+ * A modifier is a function that is called each time Popper.js needs to
311
+ * compute the position of the popper.
312
+ * For this reason, modifiers should be very performant to avoid bottlenecks.
313
+ * To learn how to create a modifier, [read the modifiers documentation](https://popper.js.org/docs/v2/modifiers/).
314
+ */
315
+ modifiers: PropTypes.arrayOf(PropTypes.shape({
316
+ data: PropTypes.object,
317
+ effect: PropTypes.func,
318
+ enabled: PropTypes.bool,
319
+ fn: PropTypes.func,
320
+ name: PropTypes.any,
321
+ options: PropTypes.object,
322
+ phase: PropTypes.oneOf(['afterMain', 'afterRead', 'afterWrite', 'beforeMain', 'beforeRead', 'beforeWrite', 'main', 'read', 'write']),
323
+ requires: PropTypes.arrayOf(PropTypes.string),
324
+ requiresIfExists: PropTypes.arrayOf(PropTypes.string)
325
+ })),
326
+ /**
327
+ * If `true`, the component is shown.
328
+ */
329
+ open: PropTypes.bool.isRequired,
330
+ /**
331
+ * Popper placement.
332
+ * @default 'bottom'
333
+ */
334
+ placement: PropTypes.oneOf(['auto-end', 'auto-start', 'auto', 'bottom-end', 'bottom-start', 'bottom', 'left-end', 'left-start', 'left', 'right-end', 'right-start', 'right', 'top-end', 'top-start', 'top']),
335
+ /**
336
+ * Options provided to the [`Popper.js`](https://popper.js.org/docs/v2/constructors/#options) instance.
337
+ * @default {}
338
+ */
339
+ popperOptions: PropTypes.shape({
340
+ modifiers: PropTypes.array,
341
+ onFirstUpdate: PropTypes.func,
342
+ placement: PropTypes.oneOf(['auto-end', 'auto-start', 'auto', 'bottom-end', 'bottom-start', 'bottom', 'left-end', 'left-start', 'left', 'right-end', 'right-start', 'right', 'top-end', 'top-start', 'top']),
343
+ strategy: PropTypes.oneOf(['absolute', 'fixed'])
344
+ }),
345
+ /**
346
+ * A ref that points to the used popper instance.
347
+ */
348
+ popperRef: refType,
349
+ /**
350
+ * The props used for each slot inside the Popper.
351
+ * @default {}
352
+ */
353
+ slotProps: PropTypes.shape({
354
+ root: PropTypes.oneOfType([PropTypes.func, PropTypes.object])
355
+ }),
356
+ /**
357
+ * The components used for each slot inside the Popper.
358
+ * Either a string to use a HTML element or a component.
359
+ * @default {}
360
+ */
361
+ slots: PropTypes.shape({
362
+ root: PropTypes.elementType
363
+ }),
364
+ /**
365
+ * Help supporting a react-transition-group/Transition component.
366
+ * @default false
367
+ */
368
+ transition: PropTypes.bool
369
+ } : void 0;
370
+ export default Popper;
@@ -0,0 +1 @@
1
+ export {};
@@ -1,12 +1,13 @@
1
1
  'use client';
2
2
 
3
- import { Popper as BasePopper } from '@mui/base/Popper';
4
- import useTheme from '@mui/system/useThemeWithoutDefault';
3
+ import { useRtl } from '@mui/system/RtlProvider';
5
4
  import refType from '@mui/utils/refType';
6
5
  import HTMLElementType from '@mui/utils/HTMLElementType';
7
6
  import PropTypes from 'prop-types';
8
7
  import * as React from 'react';
9
- import { styled, useThemeProps } from '../styles';
8
+ import BasePopper from './BasePopper';
9
+ import { styled } from '../zero-styled';
10
+ import { useDefaultProps } from '../DefaultPropsProvider';
10
11
  import { jsx as _jsx } from "react/jsx-runtime";
11
12
  const PopperRoot = styled(BasePopper, {
12
13
  name: 'MuiPopper',
@@ -18,17 +19,17 @@ const PopperRoot = styled(BasePopper, {
18
19
  *
19
20
  * Demos:
20
21
  *
21
- * - [Autocomplete](https://mui.com/material-ui/react-autocomplete/)
22
- * - [Menu](https://mui.com/material-ui/react-menu/)
23
- * - [Popper](https://mui.com/material-ui/react-popper/)
22
+ * - [Autocomplete](https://next.mui.com/material-ui/react-autocomplete/)
23
+ * - [Menu](https://next.mui.com/material-ui/react-menu/)
24
+ * - [Popper](https://next.mui.com/material-ui/react-popper/)
24
25
  *
25
26
  * API:
26
27
  *
27
- * - [Popper API](https://mui.com/material-ui/api/popper/)
28
+ * - [Popper API](https://next.mui.com/material-ui/api/popper/)
28
29
  */
29
30
  const Popper = /*#__PURE__*/React.forwardRef(function Popper(inProps, ref) {
30
- const theme = useTheme();
31
- const props = useThemeProps({
31
+ const isRtl = useRtl();
32
+ const props = useDefaultProps({
32
33
  props: inProps,
33
34
  name: 'MuiPopper'
34
35
  });
@@ -66,7 +67,7 @@ const Popper = /*#__PURE__*/React.forwardRef(function Popper(inProps, ref) {
66
67
  };
67
68
  return /*#__PURE__*/_jsx(PopperRoot, {
68
69
  as: component,
69
- direction: theme?.direction,
70
+ direction: isRtl ? 'rtl' : 'ltr',
70
71
  slots: {
71
72
  root: RootComponent
72
73
  },
@@ -1,3 +1,4 @@
1
1
  'use client';
2
2
 
3
- export { default } from './Popper';
3
+ export { default } from './Popper';
4
+ export * from './popperClasses';
@@ -0,0 +1,7 @@
1
+ import generateUtilityClasses from '@mui/utils/generateUtilityClasses';
2
+ import generateUtilityClass from '@mui/utils/generateUtilityClass';
3
+ export function getPopperUtilityClass(slot) {
4
+ return generateUtilityClass('MuiPopper', slot);
5
+ }
6
+ const popperClasses = generateUtilityClasses('MuiPopper', ['root']);
7
+ export default popperClasses;
@@ -0,0 +1,92 @@
1
+ 'use client';
2
+
3
+ import * as React from 'react';
4
+ import * as ReactDOM from 'react-dom';
5
+ import PropTypes from 'prop-types';
6
+ import { exactProp, HTMLElementType, unstable_useEnhancedEffect as useEnhancedEffect, unstable_useForkRef as useForkRef, unstable_setRef as setRef } from '@mui/utils';
7
+ import { jsx as _jsx } from "react/jsx-runtime";
8
+ function getContainer(container) {
9
+ return typeof container === 'function' ? container() : container;
10
+ }
11
+
12
+ /**
13
+ * Portals provide a first-class way to render children into a DOM node
14
+ * that exists outside the DOM hierarchy of the parent component.
15
+ *
16
+ * Demos:
17
+ *
18
+ * - [Portal](https://next.mui.com/material-ui/react-portal/)
19
+ *
20
+ * API:
21
+ *
22
+ * - [Portal API](https://next.mui.com/material-ui/api/portal/)
23
+ */
24
+ const Portal = /*#__PURE__*/React.forwardRef(function Portal(props, forwardedRef) {
25
+ const {
26
+ children,
27
+ container,
28
+ disablePortal = false
29
+ } = props;
30
+ const [mountNode, setMountNode] = React.useState(null);
31
+ // @ts-expect-error TODO upstream fix
32
+ const handleRef = useForkRef( /*#__PURE__*/React.isValidElement(children) ? children.ref : null, forwardedRef);
33
+ useEnhancedEffect(() => {
34
+ if (!disablePortal) {
35
+ setMountNode(getContainer(container) || document.body);
36
+ }
37
+ }, [container, disablePortal]);
38
+ useEnhancedEffect(() => {
39
+ if (mountNode && !disablePortal) {
40
+ setRef(forwardedRef, mountNode);
41
+ return () => {
42
+ setRef(forwardedRef, null);
43
+ };
44
+ }
45
+ return undefined;
46
+ }, [forwardedRef, mountNode, disablePortal]);
47
+ if (disablePortal) {
48
+ if ( /*#__PURE__*/React.isValidElement(children)) {
49
+ const newProps = {
50
+ ref: handleRef
51
+ };
52
+ return /*#__PURE__*/React.cloneElement(children, newProps);
53
+ }
54
+ return /*#__PURE__*/_jsx(React.Fragment, {
55
+ children: children
56
+ });
57
+ }
58
+ return /*#__PURE__*/_jsx(React.Fragment, {
59
+ children: mountNode ? /*#__PURE__*/ReactDOM.createPortal(children, mountNode) : mountNode
60
+ });
61
+ });
62
+ process.env.NODE_ENV !== "production" ? Portal.propTypes /* remove-proptypes */ = {
63
+ // ┌────────────────────────────── Warning ──────────────────────────────┐
64
+ // │ These PropTypes are generated from the TypeScript type definitions. │
65
+ // │ To update them, edit the TypeScript types and run `pnpm proptypes`. │
66
+ // └─────────────────────────────────────────────────────────────────────┘
67
+ /**
68
+ * The children to render into the `container`.
69
+ */
70
+ children: PropTypes.node,
71
+ /**
72
+ * An HTML element or function that returns one.
73
+ * The `container` will have the portal children appended to it.
74
+ *
75
+ * You can also provide a callback, which is called in a React layout effect.
76
+ * This lets you set the container from a ref, and also makes server-side rendering possible.
77
+ *
78
+ * By default, it uses the body of the top-level document object,
79
+ * so it's simply `document.body` most of the time.
80
+ */
81
+ container: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([HTMLElementType, PropTypes.func]),
82
+ /**
83
+ * The `children` will be under the DOM hierarchy of the parent component.
84
+ * @default false
85
+ */
86
+ disablePortal: PropTypes.bool
87
+ } : void 0;
88
+ if (process.env.NODE_ENV !== 'production') {
89
+ // eslint-disable-next-line
90
+ Portal['propTypes' + ''] = exactProp(Portal.propTypes);
91
+ }
92
+ export default Portal;
@@ -0,0 +1 @@
1
+ export {};