@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.
- package/Accordion/Accordion.d.ts +3 -5
- package/Accordion/Accordion.js +3 -5
- package/AccordionActions/AccordionActions.d.ts +2 -2
- package/AccordionActions/AccordionActions.js +3 -3
- package/AccordionDetails/AccordionDetails.d.ts +2 -2
- package/AccordionDetails/AccordionDetails.js +3 -3
- package/AccordionSummary/AccordionSummary.d.ts +3 -3
- package/AccordionSummary/AccordionSummary.js +3 -3
- package/Alert/Alert.d.ts +15 -6
- package/Alert/Alert.js +3 -3
- package/AlertTitle/AlertTitle.d.ts +3 -3
- package/AlertTitle/AlertTitle.js +3 -3
- package/AppBar/AppBar.d.ts +3 -3
- package/AppBar/AppBar.js +5 -9
- package/Autocomplete/Autocomplete.d.ts +9 -15
- package/Autocomplete/Autocomplete.js +14 -27
- package/Avatar/Avatar.d.ts +2 -3
- package/Avatar/Avatar.js +3 -4
- package/AvatarGroup/AvatarGroup.d.ts +2 -2
- package/AvatarGroup/AvatarGroup.js +3 -3
- package/Backdrop/Backdrop.d.ts +5 -8
- package/Backdrop/Backdrop.js +5 -8
- package/Badge/Badge.d.ts +4 -4
- package/Badge/Badge.js +5 -5
- package/Badge/useBadge.d.ts +13 -0
- package/Badge/useBadge.js +41 -0
- package/Badge/useBadge.types.d.ts +40 -0
- package/Badge/useBadge.types.js +1 -0
- package/BottomNavigation/BottomNavigation.d.ts +2 -2
- package/BottomNavigation/BottomNavigation.js +3 -3
- package/BottomNavigationAction/BottomNavigationAction.d.ts +3 -3
- package/BottomNavigationAction/BottomNavigationAction.js +3 -3
- package/Box/Box.d.ts +2 -2
- package/Breadcrumbs/Breadcrumbs.d.ts +4 -4
- package/Breadcrumbs/Breadcrumbs.js +4 -4
- package/Button/Button.d.ts +4 -4
- package/Button/Button.js +3 -3
- package/ButtonBase/ButtonBase.d.ts +2 -2
- package/ButtonBase/ButtonBase.js +23 -52
- package/ButtonBase/TouchRipple.js +3 -3
- package/ButtonGroup/ButtonGroup.d.ts +2 -2
- package/ButtonGroup/ButtonGroup.js +3 -3
- package/CHANGELOG.md +363 -3
- package/Card/Card.d.ts +3 -3
- package/Card/Card.js +3 -3
- package/CardActionArea/CardActionArea.d.ts +3 -3
- package/CardActionArea/CardActionArea.js +3 -3
- package/CardActions/CardActions.d.ts +2 -2
- package/CardActions/CardActions.js +3 -3
- package/CardContent/CardContent.d.ts +2 -2
- package/CardContent/CardContent.js +3 -3
- package/CardHeader/CardHeader.d.ts +2 -2
- package/CardHeader/CardHeader.js +3 -3
- package/CardMedia/CardMedia.d.ts +2 -2
- package/CardMedia/CardMedia.js +3 -3
- package/Checkbox/Checkbox.d.ts +4 -4
- package/Checkbox/Checkbox.js +3 -3
- package/Chip/Chip.d.ts +5 -5
- package/Chip/Chip.js +3 -5
- package/CircularProgress/CircularProgress.d.ts +2 -2
- package/CircularProgress/CircularProgress.js +3 -3
- package/ClickAwayListener/ClickAwayListener.d.ts +47 -0
- package/ClickAwayListener/ClickAwayListener.js +178 -0
- package/ClickAwayListener/index.d.ts +2 -2
- package/ClickAwayListener/index.js +1 -1
- package/Collapse/Collapse.d.ts +5 -5
- package/Collapse/Collapse.js +3 -4
- package/Container/Container.d.ts +2 -2
- package/CssBaseline/CssBaseline.d.ts +2 -2
- package/CssBaseline/CssBaseline.js +66 -8
- package/DefaultPropsProvider/DefaultPropsProvider.d.ts +15 -0
- package/DefaultPropsProvider/DefaultPropsProvider.js +29 -0
- package/DefaultPropsProvider/index.d.ts +1 -0
- package/DefaultPropsProvider/index.js +1 -0
- package/DefaultPropsProvider/package.json +6 -0
- package/Dialog/Dialog.d.ts +3 -3
- package/Dialog/Dialog.js +4 -7
- package/DialogActions/DialogActions.d.ts +2 -2
- package/DialogActions/DialogActions.js +3 -3
- package/DialogContent/DialogContent.d.ts +2 -2
- package/DialogContent/DialogContent.js +3 -3
- package/DialogContentText/DialogContentText.d.ts +3 -3
- package/DialogContentText/DialogContentText.js +3 -3
- package/DialogTitle/DialogTitle.d.ts +3 -3
- package/DialogTitle/DialogTitle.js +3 -3
- package/Divider/Divider.d.ts +3 -3
- package/Divider/Divider.js +3 -3
- package/Drawer/Drawer.d.ts +3 -3
- package/Drawer/Drawer.js +3 -4
- package/Fab/Fab.d.ts +3 -3
- package/Fab/Fab.js +3 -3
- package/Fade/Fade.d.ts +3 -3
- package/Fade/Fade.js +1 -1
- package/FilledInput/FilledInput.d.ts +3 -3
- package/FilledInput/FilledInput.js +13 -11
- package/FilledInput/filledInputClasses.d.ts +1 -13
- package/FilledInput/filledInputClasses.js +1 -1
- package/FormControl/FormControl.d.ts +6 -6
- package/FormControl/FormControl.js +3 -3
- package/FormControlLabel/FormControlLabel.d.ts +4 -4
- package/FormControlLabel/FormControlLabel.js +3 -3
- package/FormGroup/FormGroup.d.ts +3 -3
- package/FormGroup/FormGroup.js +3 -3
- package/FormHelperText/FormHelperText.d.ts +2 -2
- package/FormHelperText/FormHelperText.js +3 -3
- package/FormLabel/FormLabel.d.ts +4 -4
- package/FormLabel/FormLabel.js +3 -3
- package/GlobalStyles/GlobalStyles.d.ts +3 -3
- package/Grid/Grid.d.ts +2 -2
- package/Grid/Grid.js +7 -13
- package/Grow/Grow.d.ts +5 -5
- package/Grow/Grow.js +1 -1
- package/Hidden/Hidden.d.ts +2 -2
- package/Hidden/hiddenCssClasses.d.ts +3 -0
- package/Icon/Icon.d.ts +3 -3
- package/Icon/Icon.js +3 -3
- package/IconButton/IconButton.d.ts +4 -4
- package/IconButton/IconButton.js +3 -5
- package/ImageList/ImageList.d.ts +2 -2
- package/ImageList/ImageList.js +3 -11
- package/ImageListItem/ImageListItem.d.ts +2 -2
- package/ImageListItem/ImageListItem.js +3 -3
- package/ImageListItemBar/ImageListItemBar.d.ts +2 -2
- package/ImageListItemBar/ImageListItemBar.js +3 -3
- package/InitColorSchemeScript/InitColorSchemeScript.d.ts +10 -0
- package/InitColorSchemeScript/InitColorSchemeScript.js +16 -0
- package/InitColorSchemeScript/index.d.ts +1 -0
- package/InitColorSchemeScript/index.js +1 -0
- package/InitColorSchemeScript/package.json +6 -0
- package/Input/Input.d.ts +3 -3
- package/Input/Input.js +5 -9
- package/InputAdornment/InputAdornment.d.ts +2 -2
- package/InputAdornment/InputAdornment.js +3 -5
- package/InputBase/InputBase.d.ts +4 -6
- package/InputBase/InputBase.js +33 -42
- package/InputLabel/InputLabel.d.ts +3 -3
- package/InputLabel/InputLabel.js +3 -3
- package/LinearProgress/LinearProgress.d.ts +2 -2
- package/LinearProgress/LinearProgress.js +3 -3
- package/Link/Link.d.ts +4 -4
- package/Link/Link.js +7 -18
- package/List/List.d.ts +3 -3
- package/List/List.js +3 -3
- package/ListItem/ListItem.d.ts +3 -3
- package/ListItem/ListItem.js +4 -4
- package/ListItemAvatar/ListItemAvatar.d.ts +2 -2
- package/ListItemAvatar/ListItemAvatar.js +3 -3
- package/ListItemButton/ListItemButton.d.ts +3 -3
- package/ListItemButton/ListItemButton.js +3 -3
- package/ListItemIcon/ListItemIcon.d.ts +2 -2
- package/ListItemIcon/ListItemIcon.js +3 -3
- package/ListItemSecondaryAction/ListItemSecondaryAction.d.ts +2 -2
- package/ListItemSecondaryAction/ListItemSecondaryAction.js +3 -3
- package/ListItemText/ListItemText.d.ts +2 -2
- package/ListItemText/ListItemText.js +3 -3
- package/ListSubheader/ListSubheader.d.ts +2 -2
- package/ListSubheader/ListSubheader.js +3 -3
- package/Menu/Menu.d.ts +4 -4
- package/Menu/Menu.js +5 -8
- package/MenuItem/MenuItem.d.ts +3 -3
- package/MenuItem/MenuItem.js +3 -3
- package/MenuList/MenuList.d.ts +4 -4
- package/MobileStepper/MobileStepper.d.ts +3 -3
- package/MobileStepper/MobileStepper.js +3 -3
- package/Modal/Modal.d.ts +11 -13
- package/Modal/Modal.js +33 -25
- package/Modal/ModalManager.d.ts +25 -0
- package/Modal/ModalManager.js +211 -0
- package/Modal/index.d.ts +1 -1
- package/Modal/index.js +1 -1
- package/Modal/useModal.d.ts +13 -0
- package/Modal/useModal.js +195 -0
- package/Modal/useModal.types.d.ts +115 -0
- package/Modal/useModal.types.js +1 -0
- package/NativeSelect/NativeSelect.d.ts +3 -3
- package/NativeSelect/NativeSelectInput.js +0 -4
- package/NoSsr/NoSsr.d.ts +25 -0
- package/NoSsr/NoSsr.js +73 -0
- package/NoSsr/NoSsr.types.d.ts +18 -0
- package/NoSsr/NoSsr.types.js +1 -0
- package/NoSsr/index.d.ts +3 -2
- package/NoSsr/index.js +1 -1
- package/OutlinedInput/OutlinedInput.d.ts +3 -3
- package/OutlinedInput/OutlinedInput.js +4 -5
- package/Pagination/Pagination.d.ts +2 -2
- package/Pagination/Pagination.js +3 -3
- package/PaginationItem/PaginationItem.d.ts +2 -2
- package/PaginationItem/PaginationItem.js +3 -3
- package/Paper/Paper.d.ts +3 -3
- package/Paper/Paper.js +3 -4
- package/PigmentContainer/PigmentContainer.d.ts +55 -0
- package/PigmentContainer/PigmentContainer.js +98 -0
- package/PigmentContainer/index.d.ts +3 -0
- package/PigmentContainer/index.js +3 -0
- package/PigmentContainer/package.json +6 -0
- package/PigmentGrid/PigmentGrid.d.ts +108 -0
- package/PigmentGrid/PigmentGrid.js +149 -0
- package/PigmentGrid/index.d.ts +3 -0
- package/PigmentGrid/index.js +3 -0
- package/{useTouchRipple → PigmentGrid}/package.json +1 -1
- package/PigmentHidden/PigmentHidden.d.ts +97 -0
- package/PigmentHidden/PigmentHidden.js +278 -0
- package/PigmentHidden/index.d.ts +2 -0
- package/PigmentHidden/index.js +2 -0
- package/PigmentHidden/package.json +6 -0
- package/PigmentStack/PigmentStack.d.ts +51 -0
- package/PigmentStack/PigmentStack.js +81 -0
- package/PigmentStack/index.d.ts +3 -0
- package/PigmentStack/index.js +3 -0
- package/PigmentStack/package.json +6 -0
- package/Popover/Popover.d.ts +20 -25
- package/Popover/Popover.js +30 -29
- package/Popper/BasePopper.d.ts +7 -0
- package/Popper/BasePopper.js +370 -0
- package/Popper/BasePopper.types.d.ts +130 -0
- package/Popper/BasePopper.types.js +1 -0
- package/Popper/Popper.d.ts +5 -5
- package/Popper/Popper.js +11 -10
- package/Popper/index.d.ts +2 -1
- package/Popper/index.js +2 -1
- package/Popper/popperClasses.d.ts +8 -0
- package/Popper/popperClasses.js +7 -0
- package/Portal/Portal.d.ts +16 -0
- package/Portal/Portal.js +92 -0
- package/Portal/Portal.types.d.ts +23 -0
- package/Portal/Portal.types.js +1 -0
- package/Portal/index.d.ts +3 -2
- package/Portal/index.js +1 -1
- package/Radio/Radio.d.ts +3 -3
- package/Radio/Radio.js +3 -3
- package/RadioGroup/RadioGroup.d.ts +3 -3
- package/Rating/Rating.d.ts +2 -2
- package/Rating/Rating.js +8 -15
- package/ScopedCssBaseline/ScopedCssBaseline.d.ts +2 -2
- package/ScopedCssBaseline/ScopedCssBaseline.js +24 -11
- package/Select/Select.d.ts +3 -3
- package/Skeleton/Skeleton.d.ts +2 -2
- package/Skeleton/Skeleton.js +3 -3
- package/Slide/Slide.d.ts +4 -4
- package/Slide/Slide.js +1 -1
- package/Slider/Slider.d.ts +5 -5
- package/Slider/Slider.js +6 -5
- package/Slider/useSlider.d.ts +14 -0
- package/Slider/useSlider.js +647 -0
- package/Slider/useSlider.types.d.ts +228 -0
- package/Slider/useSlider.types.js +1 -0
- package/Snackbar/Snackbar.d.ts +3 -3
- package/Snackbar/Snackbar.js +6 -7
- package/Snackbar/useSnackbar.d.ts +14 -0
- package/Snackbar/useSnackbar.js +133 -0
- package/Snackbar/useSnackbar.types.d.ts +60 -0
- package/Snackbar/useSnackbar.types.js +1 -0
- package/SnackbarContent/SnackbarContent.d.ts +3 -3
- package/SnackbarContent/SnackbarContent.js +3 -3
- package/SpeedDial/SpeedDial.d.ts +2 -4
- package/SpeedDial/SpeedDial.js +3 -6
- package/SpeedDialAction/SpeedDialAction.d.ts +3 -3
- package/SpeedDialAction/SpeedDialAction.js +3 -3
- package/SpeedDialIcon/SpeedDialIcon.d.ts +2 -2
- package/SpeedDialIcon/SpeedDialIcon.js +3 -3
- package/Stack/Stack.d.ts +2 -2
- package/Step/Step.d.ts +2 -2
- package/Step/Step.js +3 -3
- package/StepButton/StepButton.d.ts +3 -3
- package/StepButton/StepButton.js +3 -3
- package/StepConnector/StepConnector.d.ts +3 -3
- package/StepConnector/StepConnector.js +3 -3
- package/StepContent/StepContent.d.ts +2 -2
- package/StepContent/StepContent.js +3 -3
- package/StepIcon/StepIcon.d.ts +2 -2
- package/StepIcon/StepIcon.js +3 -3
- package/StepLabel/StepLabel.d.ts +2 -4
- package/StepLabel/StepLabel.js +3 -7
- package/Stepper/Stepper.d.ts +2 -2
- package/Stepper/Stepper.js +7 -5
- package/Stepper/stepperClasses.d.ts +2 -0
- package/Stepper/stepperClasses.js +1 -1
- package/SvgIcon/SvgIcon.d.ts +3 -3
- package/SvgIcon/SvgIcon.js +3 -3
- package/SwipeableDrawer/SwipeableDrawer.d.ts +3 -3
- package/SwipeableDrawer/SwipeableDrawer.js +4 -4
- package/Switch/Switch.d.ts +4 -4
- package/Switch/Switch.js +3 -3
- package/Tab/Tab.d.ts +4 -4
- package/Tab/Tab.js +14 -10
- package/Tab/tabClasses.d.ts +5 -1
- package/Tab/tabClasses.js +1 -1
- package/TabScrollButton/TabScrollButton.d.ts +3 -3
- package/TabScrollButton/TabScrollButton.js +4 -4
- package/Table/Table.d.ts +2 -2
- package/Table/Table.js +3 -3
- package/TableBody/TableBody.d.ts +2 -2
- package/TableBody/TableBody.js +3 -3
- package/TableCell/TableCell.d.ts +2 -2
- package/TableCell/TableCell.js +3 -3
- package/TableContainer/TableContainer.d.ts +2 -2
- package/TableContainer/TableContainer.js +3 -3
- package/TableFooter/TableFooter.d.ts +2 -2
- package/TableFooter/TableFooter.js +3 -3
- package/TableHead/TableHead.d.ts +2 -2
- package/TableHead/TableHead.js +3 -3
- package/TablePagination/TablePagination.d.ts +4 -4
- package/TablePagination/TablePagination.js +4 -4
- package/TableRow/TableRow.d.ts +2 -2
- package/TableRow/TableRow.js +3 -3
- package/TableSortLabel/TableSortLabel.d.ts +3 -3
- package/TableSortLabel/TableSortLabel.js +4 -4
- package/TableSortLabel/tableSortLabelClasses.d.ts +10 -2
- package/TableSortLabel/tableSortLabelClasses.js +1 -1
- package/Tabs/Tabs.d.ts +3 -3
- package/Tabs/Tabs.js +6 -15
- package/TextField/TextField.d.ts +10 -10
- package/TextField/TextField.js +3 -3
- package/TextareaAutosize/TextareaAutosize.d.ts +14 -0
- package/TextareaAutosize/TextareaAutosize.js +222 -0
- package/TextareaAutosize/TextareaAutosize.types.d.ts +13 -0
- package/TextareaAutosize/TextareaAutosize.types.js +1 -0
- package/TextareaAutosize/index.d.ts +3 -2
- package/TextareaAutosize/index.js +1 -1
- package/ToggleButton/ToggleButton.d.ts +3 -3
- package/ToggleButton/ToggleButton.js +3 -3
- package/ToggleButtonGroup/ToggleButtonGroup.d.ts +2 -2
- package/ToggleButtonGroup/ToggleButtonGroup.js +3 -3
- package/Toolbar/Toolbar.d.ts +2 -2
- package/Toolbar/Toolbar.js +3 -3
- package/Tooltip/Tooltip.d.ts +2 -2
- package/Tooltip/Tooltip.js +8 -19
- package/Typography/Typography.d.ts +3 -3
- package/Typography/Typography.js +4 -4
- package/Unstable_TrapFocus/FocusTrap.d.ts +10 -0
- package/Unstable_TrapFocus/FocusTrap.js +330 -0
- package/Unstable_TrapFocus/FocusTrap.types.d.ts +51 -0
- package/Unstable_TrapFocus/FocusTrap.types.js +1 -0
- package/Unstable_TrapFocus/index.d.ts +2 -2
- package/Unstable_TrapFocus/index.js +1 -1
- package/Zoom/Zoom.d.ts +3 -3
- package/Zoom/Zoom.js +1 -1
- package/index.d.ts +1 -1
- package/index.js +2 -2
- package/modern/Accordion/Accordion.js +3 -5
- package/modern/AccordionActions/AccordionActions.js +3 -3
- package/modern/AccordionDetails/AccordionDetails.js +3 -3
- package/modern/AccordionSummary/AccordionSummary.js +3 -3
- package/modern/Alert/Alert.js +3 -3
- package/modern/AlertTitle/AlertTitle.js +3 -3
- package/modern/AppBar/AppBar.js +5 -9
- package/modern/Autocomplete/Autocomplete.js +14 -27
- package/modern/Avatar/Avatar.js +3 -4
- package/modern/AvatarGroup/AvatarGroup.js +3 -3
- package/modern/Backdrop/Backdrop.js +5 -8
- package/modern/Badge/Badge.js +5 -5
- package/modern/Badge/useBadge.js +41 -0
- package/modern/Badge/useBadge.types.js +1 -0
- package/modern/BottomNavigation/BottomNavigation.js +3 -3
- package/modern/BottomNavigationAction/BottomNavigationAction.js +3 -3
- package/modern/Breadcrumbs/Breadcrumbs.js +4 -4
- package/modern/Button/Button.js +3 -3
- package/modern/ButtonBase/ButtonBase.js +23 -52
- package/modern/ButtonBase/TouchRipple.js +3 -3
- package/modern/ButtonGroup/ButtonGroup.js +3 -3
- package/modern/Card/Card.js +3 -3
- package/modern/CardActionArea/CardActionArea.js +3 -3
- package/modern/CardActions/CardActions.js +3 -3
- package/modern/CardContent/CardContent.js +3 -3
- package/modern/CardHeader/CardHeader.js +3 -3
- package/modern/CardMedia/CardMedia.js +3 -3
- package/modern/Checkbox/Checkbox.js +3 -3
- package/modern/Chip/Chip.js +3 -5
- package/modern/CircularProgress/CircularProgress.js +3 -3
- package/modern/ClickAwayListener/ClickAwayListener.js +178 -0
- package/modern/ClickAwayListener/index.js +1 -1
- package/modern/Collapse/Collapse.js +3 -4
- package/modern/CssBaseline/CssBaseline.js +66 -8
- package/modern/DefaultPropsProvider/DefaultPropsProvider.js +29 -0
- package/modern/DefaultPropsProvider/index.js +1 -0
- package/modern/Dialog/Dialog.js +4 -7
- package/modern/DialogActions/DialogActions.js +3 -3
- package/modern/DialogContent/DialogContent.js +3 -3
- package/modern/DialogContentText/DialogContentText.js +3 -3
- package/modern/DialogTitle/DialogTitle.js +3 -3
- package/modern/Divider/Divider.js +3 -3
- package/modern/Drawer/Drawer.js +3 -4
- package/modern/Fab/Fab.js +3 -3
- package/modern/Fade/Fade.js +1 -1
- package/modern/FilledInput/FilledInput.js +13 -11
- package/modern/FilledInput/filledInputClasses.js +1 -1
- package/modern/FormControl/FormControl.js +3 -3
- package/modern/FormControlLabel/FormControlLabel.js +3 -3
- package/modern/FormGroup/FormGroup.js +3 -3
- package/modern/FormHelperText/FormHelperText.js +3 -3
- package/modern/FormLabel/FormLabel.js +3 -3
- package/modern/Grid/Grid.js +7 -13
- package/modern/Grow/Grow.js +1 -1
- package/modern/Icon/Icon.js +3 -3
- package/modern/IconButton/IconButton.js +3 -5
- package/modern/ImageList/ImageList.js +3 -11
- package/modern/ImageListItem/ImageListItem.js +3 -3
- package/modern/ImageListItemBar/ImageListItemBar.js +3 -3
- package/modern/InitColorSchemeScript/InitColorSchemeScript.js +16 -0
- package/modern/InitColorSchemeScript/index.js +1 -0
- package/modern/Input/Input.js +5 -9
- package/modern/InputAdornment/InputAdornment.js +3 -5
- package/modern/InputBase/InputBase.js +33 -42
- package/modern/InputLabel/InputLabel.js +3 -3
- package/modern/LinearProgress/LinearProgress.js +3 -3
- package/modern/Link/Link.js +7 -18
- package/modern/List/List.js +3 -3
- package/modern/ListItem/ListItem.js +4 -4
- package/modern/ListItemAvatar/ListItemAvatar.js +3 -3
- package/modern/ListItemButton/ListItemButton.js +3 -3
- package/modern/ListItemIcon/ListItemIcon.js +3 -3
- package/modern/ListItemSecondaryAction/ListItemSecondaryAction.js +3 -3
- package/modern/ListItemText/ListItemText.js +3 -3
- package/modern/ListSubheader/ListSubheader.js +3 -3
- package/modern/Menu/Menu.js +5 -8
- package/modern/MenuItem/MenuItem.js +3 -3
- package/modern/MobileStepper/MobileStepper.js +3 -3
- package/modern/Modal/Modal.js +33 -25
- package/modern/Modal/ModalManager.js +211 -0
- package/modern/Modal/index.js +1 -1
- package/modern/Modal/useModal.js +195 -0
- package/modern/Modal/useModal.types.js +1 -0
- package/modern/NativeSelect/NativeSelectInput.js +0 -4
- package/modern/NoSsr/NoSsr.js +73 -0
- package/modern/NoSsr/NoSsr.types.js +1 -0
- package/modern/NoSsr/index.js +1 -1
- package/modern/OutlinedInput/OutlinedInput.js +4 -5
- package/modern/Pagination/Pagination.js +3 -3
- package/modern/PaginationItem/PaginationItem.js +3 -3
- package/modern/Paper/Paper.js +3 -4
- package/modern/PigmentContainer/PigmentContainer.js +98 -0
- package/modern/PigmentContainer/index.js +3 -0
- package/modern/PigmentGrid/PigmentGrid.js +149 -0
- package/modern/PigmentGrid/index.js +3 -0
- package/modern/PigmentHidden/PigmentHidden.js +278 -0
- package/modern/PigmentHidden/index.js +2 -0
- package/modern/PigmentStack/PigmentStack.js +81 -0
- package/modern/PigmentStack/index.js +3 -0
- package/modern/Popover/Popover.js +30 -29
- package/modern/Popper/BasePopper.js +370 -0
- package/modern/Popper/BasePopper.types.js +1 -0
- package/modern/Popper/Popper.js +11 -10
- package/modern/Popper/index.js +2 -1
- package/modern/Popper/popperClasses.js +7 -0
- package/modern/Portal/Portal.js +92 -0
- package/modern/Portal/Portal.types.js +1 -0
- package/modern/Portal/index.js +1 -1
- package/modern/Radio/Radio.js +3 -3
- package/modern/Rating/Rating.js +8 -15
- package/modern/ScopedCssBaseline/ScopedCssBaseline.js +24 -11
- package/modern/Skeleton/Skeleton.js +3 -3
- package/modern/Slide/Slide.js +1 -1
- package/modern/Slider/Slider.js +6 -5
- package/modern/Slider/useSlider.js +647 -0
- package/modern/Slider/useSlider.types.js +1 -0
- package/modern/Snackbar/Snackbar.js +6 -7
- package/modern/Snackbar/useSnackbar.js +133 -0
- package/modern/Snackbar/useSnackbar.types.js +1 -0
- package/modern/SnackbarContent/SnackbarContent.js +3 -3
- package/modern/SpeedDial/SpeedDial.js +3 -6
- package/modern/SpeedDialAction/SpeedDialAction.js +3 -3
- package/modern/SpeedDialIcon/SpeedDialIcon.js +3 -3
- package/modern/Step/Step.js +3 -3
- package/modern/StepButton/StepButton.js +3 -3
- package/modern/StepConnector/StepConnector.js +3 -3
- package/modern/StepContent/StepContent.js +3 -3
- package/modern/StepIcon/StepIcon.js +3 -3
- package/modern/StepLabel/StepLabel.js +3 -7
- package/modern/Stepper/Stepper.js +7 -5
- package/modern/Stepper/stepperClasses.js +1 -1
- package/modern/SvgIcon/SvgIcon.js +3 -3
- package/modern/SwipeableDrawer/SwipeableDrawer.js +4 -4
- package/modern/Switch/Switch.js +3 -3
- package/modern/Tab/Tab.js +14 -10
- package/modern/Tab/tabClasses.js +1 -1
- package/modern/TabScrollButton/TabScrollButton.js +4 -4
- package/modern/Table/Table.js +3 -3
- package/modern/TableBody/TableBody.js +3 -3
- package/modern/TableCell/TableCell.js +3 -3
- package/modern/TableContainer/TableContainer.js +3 -3
- package/modern/TableFooter/TableFooter.js +3 -3
- package/modern/TableHead/TableHead.js +3 -3
- package/modern/TablePagination/TablePagination.js +4 -4
- package/modern/TableRow/TableRow.js +3 -3
- package/modern/TableSortLabel/TableSortLabel.js +4 -4
- package/modern/TableSortLabel/tableSortLabelClasses.js +1 -1
- package/modern/Tabs/Tabs.js +6 -15
- package/modern/TextField/TextField.js +3 -3
- package/modern/TextareaAutosize/TextareaAutosize.js +222 -0
- package/modern/TextareaAutosize/TextareaAutosize.types.js +1 -0
- package/modern/TextareaAutosize/index.js +1 -1
- package/modern/ToggleButton/ToggleButton.js +3 -3
- package/modern/ToggleButtonGroup/ToggleButtonGroup.js +3 -3
- package/modern/Toolbar/Toolbar.js +3 -3
- package/modern/Tooltip/Tooltip.js +8 -19
- package/modern/Typography/Typography.js +4 -4
- package/modern/Unstable_TrapFocus/FocusTrap.js +330 -0
- package/modern/Unstable_TrapFocus/FocusTrap.types.js +1 -0
- package/modern/Unstable_TrapFocus/index.js +1 -1
- package/modern/Zoom/Zoom.js +1 -1
- package/modern/index.js +2 -2
- package/modern/styles/CssVarsProvider.js +19 -7
- package/modern/styles/createTheme.js +1 -1
- package/modern/styles/createTransitions.js +2 -2
- package/modern/styles/extendTheme.js +3 -0
- package/modern/styles/index.js +1 -1
- package/modern/styles/stringifyTheme.js +55 -0
- package/modern/useAutocomplete/useAutocomplete.js +976 -2
- package/modern/useLazyRipple/index.js +3 -0
- package/modern/useLazyRipple/useLazyRipple.js +85 -0
- package/modern/usePagination/usePagination.js +1 -1
- package/modern/utils/PolymorphicComponent.js +1 -0
- package/modern/utils/areArraysEqual.js +4 -0
- package/modern/utils/index.js +1 -2
- package/modern/utils/isHostComponent.js +7 -0
- package/modern/utils/omitEventHandlers.js +18 -0
- package/modern/utils/shouldSpreadAdditionalProps.js +1 -1
- package/modern/utils/useSlot.js +3 -1
- package/modern/zero-styled/index.js +24 -5
- package/node/Accordion/Accordion.js +2 -4
- package/node/AccordionActions/AccordionActions.js +2 -2
- package/node/AccordionDetails/AccordionDetails.js +2 -2
- package/node/AccordionSummary/AccordionSummary.js +2 -2
- package/node/Alert/Alert.js +2 -2
- package/node/AlertTitle/AlertTitle.js +2 -2
- package/node/AppBar/AppBar.js +4 -8
- package/node/Autocomplete/Autocomplete.js +15 -28
- package/node/Avatar/Avatar.js +2 -3
- package/node/AvatarGroup/AvatarGroup.js +2 -2
- package/node/Backdrop/Backdrop.js +4 -7
- package/node/Badge/Badge.js +7 -7
- package/node/Badge/useBadge.js +46 -0
- package/node/Badge/useBadge.types.js +5 -0
- package/node/BottomNavigation/BottomNavigation.js +2 -2
- package/node/BottomNavigationAction/BottomNavigationAction.js +2 -2
- package/node/Breadcrumbs/Breadcrumbs.js +4 -4
- package/node/Button/Button.js +2 -2
- package/node/ButtonBase/ButtonBase.js +22 -51
- package/node/ButtonBase/TouchRipple.js +2 -2
- package/node/ButtonGroup/ButtonGroup.js +2 -2
- package/node/Card/Card.js +2 -2
- package/node/CardActionArea/CardActionArea.js +2 -2
- package/node/CardActions/CardActions.js +2 -2
- package/node/CardContent/CardContent.js +2 -2
- package/node/CardHeader/CardHeader.js +2 -2
- package/node/CardMedia/CardMedia.js +2 -2
- package/node/Checkbox/Checkbox.js +2 -2
- package/node/Chip/Chip.js +2 -4
- package/node/CircularProgress/CircularProgress.js +2 -2
- package/node/ClickAwayListener/ClickAwayListener.js +184 -0
- package/node/ClickAwayListener/index.js +1 -1
- package/node/Collapse/Collapse.js +3 -4
- package/node/CssBaseline/CssBaseline.js +70 -10
- package/node/DefaultPropsProvider/DefaultPropsProvider.js +38 -0
- package/node/DefaultPropsProvider/index.js +20 -0
- package/node/Dialog/Dialog.js +4 -7
- package/node/DialogActions/DialogActions.js +2 -2
- package/node/DialogContent/DialogContent.js +2 -2
- package/node/DialogContentText/DialogContentText.js +2 -2
- package/node/DialogTitle/DialogTitle.js +2 -2
- package/node/Divider/Divider.js +2 -2
- package/node/Drawer/Drawer.js +3 -4
- package/node/Fab/Fab.js +2 -2
- package/node/Fade/Fade.js +2 -2
- package/node/FilledInput/FilledInput.js +12 -10
- package/node/FilledInput/filledInputClasses.js +1 -1
- package/node/FormControl/FormControl.js +2 -2
- package/node/FormControlLabel/FormControlLabel.js +2 -2
- package/node/FormGroup/FormGroup.js +2 -2
- package/node/FormHelperText/FormHelperText.js +2 -2
- package/node/FormLabel/FormLabel.js +2 -2
- package/node/Grid/Grid.js +7 -13
- package/node/Grow/Grow.js +2 -2
- package/node/Icon/Icon.js +2 -2
- package/node/IconButton/IconButton.js +2 -4
- package/node/ImageList/ImageList.js +2 -10
- package/node/ImageListItem/ImageListItem.js +2 -2
- package/node/ImageListItemBar/ImageListItemBar.js +2 -2
- package/node/InitColorSchemeScript/InitColorSchemeScript.js +25 -0
- package/node/InitColorSchemeScript/index.js +13 -0
- package/node/Input/Input.js +4 -8
- package/node/InputAdornment/InputAdornment.js +2 -4
- package/node/InputBase/InputBase.js +37 -46
- package/node/InputLabel/InputLabel.js +2 -2
- package/node/LinearProgress/LinearProgress.js +2 -2
- package/node/Link/Link.js +7 -18
- package/node/List/List.js +2 -2
- package/node/ListItem/ListItem.js +5 -5
- package/node/ListItemAvatar/ListItemAvatar.js +2 -2
- package/node/ListItemButton/ListItemButton.js +2 -2
- package/node/ListItemIcon/ListItemIcon.js +2 -2
- package/node/ListItemSecondaryAction/ListItemSecondaryAction.js +2 -2
- package/node/ListItemText/ListItemText.js +2 -2
- package/node/ListSubheader/ListSubheader.js +2 -2
- package/node/Menu/Menu.js +6 -9
- package/node/MenuItem/MenuItem.js +2 -2
- package/node/MobileStepper/MobileStepper.js +2 -2
- package/node/Modal/Modal.js +33 -26
- package/node/Modal/ModalManager.js +219 -0
- package/node/Modal/index.js +2 -2
- package/node/Modal/useModal.js +205 -0
- package/node/Modal/useModal.types.js +5 -0
- package/node/NativeSelect/NativeSelectInput.js +0 -4
- package/node/NoSsr/NoSsr.js +81 -0
- package/node/NoSsr/NoSsr.types.js +5 -0
- package/node/NoSsr/index.js +3 -2
- package/node/OutlinedInput/OutlinedInput.js +3 -4
- package/node/Pagination/Pagination.js +2 -2
- package/node/PaginationItem/PaginationItem.js +2 -2
- package/node/Paper/Paper.js +3 -4
- package/node/PigmentContainer/PigmentContainer.js +108 -0
- package/node/PigmentContainer/index.js +36 -0
- package/node/PigmentGrid/PigmentGrid.js +159 -0
- package/node/PigmentGrid/index.js +36 -0
- package/node/PigmentHidden/PigmentHidden.js +287 -0
- package/node/PigmentHidden/index.js +26 -0
- package/node/PigmentStack/PigmentStack.js +91 -0
- package/node/PigmentStack/index.js +36 -0
- package/node/Popover/Popover.js +31 -30
- package/node/Popper/BasePopper.js +379 -0
- package/node/Popper/BasePopper.types.js +5 -0
- package/node/Popper/Popper.js +12 -11
- package/node/Popper/index.js +14 -1
- package/node/Popper/popperClasses.js +15 -0
- package/node/Portal/Portal.js +100 -0
- package/node/Portal/Portal.types.js +5 -0
- package/node/Portal/index.js +3 -2
- package/node/Radio/Radio.js +2 -2
- package/node/Rating/Rating.js +6 -13
- package/node/ScopedCssBaseline/ScopedCssBaseline.js +27 -13
- package/node/Skeleton/Skeleton.js +2 -2
- package/node/Slide/Slide.js +2 -2
- package/node/Slider/Slider.js +16 -15
- package/node/Slider/useSlider.js +670 -0
- package/node/Slider/useSlider.types.js +5 -0
- package/node/Snackbar/Snackbar.js +9 -10
- package/node/Snackbar/useSnackbar.js +141 -0
- package/node/Snackbar/useSnackbar.types.js +5 -0
- package/node/SnackbarContent/SnackbarContent.js +2 -2
- package/node/SpeedDial/SpeedDial.js +3 -6
- package/node/SpeedDialAction/SpeedDialAction.js +2 -2
- package/node/SpeedDialIcon/SpeedDialIcon.js +2 -2
- package/node/Step/Step.js +2 -2
- package/node/StepButton/StepButton.js +2 -2
- package/node/StepConnector/StepConnector.js +2 -2
- package/node/StepContent/StepContent.js +2 -2
- package/node/StepIcon/StepIcon.js +2 -2
- package/node/StepLabel/StepLabel.js +2 -6
- package/node/Stepper/Stepper.js +6 -4
- package/node/Stepper/stepperClasses.js +1 -1
- package/node/SvgIcon/SvgIcon.js +2 -2
- package/node/SwipeableDrawer/SwipeableDrawer.js +6 -6
- package/node/Switch/Switch.js +2 -2
- package/node/Tab/Tab.js +13 -9
- package/node/Tab/tabClasses.js +1 -1
- package/node/TabScrollButton/TabScrollButton.js +5 -5
- package/node/Table/Table.js +2 -2
- package/node/TableBody/TableBody.js +2 -2
- package/node/TableCell/TableCell.js +2 -2
- package/node/TableContainer/TableContainer.js +2 -2
- package/node/TableFooter/TableFooter.js +2 -2
- package/node/TableHead/TableHead.js +2 -2
- package/node/TablePagination/TablePagination.js +4 -4
- package/node/TableRow/TableRow.js +2 -2
- package/node/TableSortLabel/TableSortLabel.js +3 -3
- package/node/TableSortLabel/tableSortLabelClasses.js +1 -1
- package/node/Tabs/Tabs.js +8 -17
- package/node/TextField/TextField.js +2 -2
- package/node/TextareaAutosize/TextareaAutosize.js +230 -0
- package/node/TextareaAutosize/TextareaAutosize.types.js +5 -0
- package/node/TextareaAutosize/index.js +3 -2
- package/node/ToggleButton/ToggleButton.js +2 -2
- package/node/ToggleButtonGroup/ToggleButtonGroup.js +2 -2
- package/node/Toolbar/Toolbar.js +2 -2
- package/node/Tooltip/Tooltip.js +12 -23
- package/node/Typography/Typography.js +4 -4
- package/node/Unstable_TrapFocus/FocusTrap.js +339 -0
- package/node/Unstable_TrapFocus/FocusTrap.types.js +5 -0
- package/node/Unstable_TrapFocus/index.js +3 -2
- package/node/Zoom/Zoom.js +2 -2
- package/node/index.js +3 -3
- package/node/styles/CssVarsProvider.js +20 -8
- package/node/styles/createTheme.js +1 -1
- package/node/styles/createTransitions.js +2 -2
- package/node/styles/extendTheme.js +3 -0
- package/node/styles/index.js +8 -1
- package/node/styles/stringifyTheme.js +62 -0
- package/node/useAutocomplete/useAutocomplete.js +985 -18
- package/node/{useTouchRipple → useLazyRipple}/index.js +2 -2
- package/node/useLazyRipple/useLazyRipple.js +104 -0
- package/node/usePagination/usePagination.js +1 -1
- package/node/utils/PolymorphicComponent.js +5 -0
- package/node/utils/areArraysEqual.js +10 -0
- package/node/utils/index.js +2 -9
- package/node/utils/isHostComponent.js +13 -0
- package/node/utils/omitEventHandlers.js +24 -0
- package/node/utils/shouldSpreadAdditionalProps.js +3 -2
- package/node/utils/useSlot.js +6 -4
- package/node/zero-styled/index.js +33 -5
- package/package.json +23 -8
- package/styles/CssVarsProvider.d.ts +3 -2
- package/styles/CssVarsProvider.js +19 -7
- package/styles/createTheme.js +1 -1
- package/styles/createTransitions.js +2 -2
- package/styles/extendTheme.js +3 -0
- package/styles/index.d.ts +1 -0
- package/styles/index.js +1 -1
- package/styles/overrides.d.ts +1 -1
- package/styles/responsiveFontSizes.d.ts +3 -4
- package/styles/stringifyTheme.d.ts +20 -0
- package/styles/stringifyTheme.js +55 -0
- package/useAutocomplete/useAutocomplete.d.ts +468 -2
- package/useAutocomplete/useAutocomplete.js +976 -2
- package/useLazyRipple/index.d.ts +1 -0
- package/useLazyRipple/index.js +3 -0
- package/useLazyRipple/package.json +6 -0
- package/useLazyRipple/useLazyRipple.d.ts +32 -0
- package/useLazyRipple/useLazyRipple.js +85 -0
- package/usePagination/usePagination.js +1 -1
- package/utils/PolymorphicComponent.d.ts +17 -0
- package/utils/PolymorphicComponent.js +1 -0
- package/utils/areArraysEqual.d.ts +3 -0
- package/utils/areArraysEqual.js +4 -0
- package/utils/index.d.ts +2 -2
- package/utils/index.js +1 -2
- package/utils/isHostComponent.d.ts +6 -0
- package/utils/isHostComponent.js +7 -0
- package/utils/omitEventHandlers.d.ts +9 -0
- package/utils/omitEventHandlers.js +18 -0
- package/utils/shouldSpreadAdditionalProps.js +1 -1
- package/utils/types.d.ts +2 -1
- package/utils/useSlot.js +3 -1
- package/zero-styled/index.d.ts +10 -2
- package/zero-styled/index.js +24 -5
- package/modern/useMediaQuery/useMediaQueryTheme.js +0 -8
- package/modern/useTouchRipple/index.js +0 -3
- package/modern/useTouchRipple/useTouchRipple.js +0 -94
- package/modern/utils/scrollLeft.js +0 -1
- package/modern/utils/useIsFocusVisible.js +0 -4
- package/node/useMediaQuery/useMediaQueryTheme.js +0 -13
- package/node/useTouchRipple/useTouchRipple.js +0 -105
- package/node/utils/scrollLeft.js +0 -18
- package/node/utils/useIsFocusVisible.js +0 -10
- package/useMediaQuery/useMediaQueryTheme.d.ts +0 -3
- package/useMediaQuery/useMediaQueryTheme.js +0 -8
- package/useTouchRipple/index.d.ts +0 -1
- package/useTouchRipple/index.js +0 -3
- package/useTouchRipple/useTouchRipple.d.ts +0 -28
- package/useTouchRipple/useTouchRipple.js +0 -94
- package/utils/scrollLeft.js +0 -1
- package/utils/useIsFocusVisible.d.ts +0 -3
- package/utils/useIsFocusVisible.js +0 -4
|
@@ -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
|
|
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 =
|
|
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
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
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
|
-
|
|
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
|
-
} =
|
|
322
|
-
elementType:
|
|
323
|
-
|
|
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
|
|
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 {};
|
package/modern/Popper/Popper.js
CHANGED
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
'use client';
|
|
2
2
|
|
|
3
|
-
import {
|
|
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
|
|
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
|
|
31
|
-
const props =
|
|
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:
|
|
70
|
+
direction: isRtl ? 'rtl' : 'ltr',
|
|
70
71
|
slots: {
|
|
71
72
|
root: RootComponent
|
|
72
73
|
},
|
package/modern/Popper/index.js
CHANGED
|
@@ -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 {};
|