diff --git a/docs/src/pages/demos/snackbars/CustomizedSnackbars.js b/docs/src/pages/demos/snackbars/CustomizedSnackbars.js index 670eda2003db02..02c2806594b5da 100644 --- a/docs/src/pages/demos/snackbars/CustomizedSnackbars.js +++ b/docs/src/pages/demos/snackbars/CustomizedSnackbars.js @@ -64,7 +64,6 @@ function MySnackbarContentWrapper(props) { } action={[ ({ overflow: 'hidden', }, appFrame: { - width: 360, - height: 360, - backgroundColor: theme.palette.background.paper, + height: 356, }, menuButton: { - marginRight: 20, + marginRight: theme.spacing(2), }, button: { marginBottom: theme.spacing(1), @@ -32,25 +30,10 @@ const useStyles = makeStyles(theme => ({ bottom: theme.spacing(2), right: theme.spacing(2), }, - fabMoveUp: { - transform: 'translate3d(0, -46px, 0)', - transition: theme.transitions.create('transform', { - duration: theme.transitions.duration.enteringScreen, - easing: theme.transitions.easing.easeOut, - }), - }, - fabMoveDown: { - transform: 'translate3d(0, 0, 0)', - transition: theme.transitions.create('transform', { - duration: theme.transitions.duration.leavingScreen, - easing: theme.transitions.easing.sharp, - }), - }, snackbar: { - position: 'absolute', - }, - snackbarContent: { - width: 360, + [theme.breakpoints.down('xs')]: { + bottom: 90, + }, }, })); @@ -66,10 +49,9 @@ function FabIntegrationSnackbar() { setOpen(false); } - const fabClassName = clsx(classes.fab, open ? classes.fabMoveUp : classes.fabMoveDown); - return (
+ @@ -89,7 +71,7 @@ function FabIntegrationSnackbar() { - + Archived} action={ diff --git a/docs/src/pages/demos/snackbars/FabIntegrationSnackbar.tsx b/docs/src/pages/demos/snackbars/FabIntegrationSnackbar.tsx index 5c17dda66eba31..9112a450218bf5 100644 --- a/docs/src/pages/demos/snackbars/FabIntegrationSnackbar.tsx +++ b/docs/src/pages/demos/snackbars/FabIntegrationSnackbar.tsx @@ -1,7 +1,7 @@ import React from 'react'; -import clsx from 'clsx'; import { makeStyles, Theme } from '@material-ui/core/styles'; import AppBar from '@material-ui/core/AppBar'; +import CssBaseline from '@material-ui/core/CssBaseline'; import Toolbar from '@material-ui/core/Toolbar'; import IconButton from '@material-ui/core/IconButton'; import MenuIcon from '@material-ui/icons/Menu'; @@ -17,12 +17,10 @@ const useStyles = makeStyles((theme: Theme) => ({ overflow: 'hidden', }, appFrame: { - width: 360, - height: 360, - backgroundColor: theme.palette.background.paper, + height: 356, }, menuButton: { - marginRight: 20, + marginRight: theme.spacing(2), }, button: { marginBottom: theme.spacing(1), @@ -32,25 +30,10 @@ const useStyles = makeStyles((theme: Theme) => ({ bottom: theme.spacing(2), right: theme.spacing(2), }, - fabMoveUp: { - transform: 'translate3d(0, -46px, 0)', - transition: theme.transitions.create('transform', { - duration: theme.transitions.duration.enteringScreen, - easing: theme.transitions.easing.easeOut, - }), - }, - fabMoveDown: { - transform: 'translate3d(0, 0, 0)', - transition: theme.transitions.create('transform', { - duration: theme.transitions.duration.leavingScreen, - easing: theme.transitions.easing.sharp, - }), - }, snackbar: { - position: 'absolute', - }, - snackbarContent: { - width: 360, + [theme.breakpoints.down('xs')]: { + bottom: 90, + }, }, })); @@ -66,10 +49,9 @@ function FabIntegrationSnackbar() { setOpen(false); } - const fabClassName = clsx(classes.fab, open ? classes.fabMoveUp : classes.fabMoveDown); - return (
+ @@ -89,7 +71,7 @@ function FabIntegrationSnackbar() { - + Archived} action={ diff --git a/docs/src/pages/demos/snackbars/FadeSnackbar.js b/docs/src/pages/demos/snackbars/FadeSnackbar.js deleted file mode 100644 index e9f96f662fc1c0..00000000000000 --- a/docs/src/pages/demos/snackbars/FadeSnackbar.js +++ /dev/null @@ -1,33 +0,0 @@ -import React from 'react'; -import Button from '@material-ui/core/Button'; -import Snackbar from '@material-ui/core/Snackbar'; -import Fade from '@material-ui/core/Fade'; - -function FadeSnackbar() { - const [open, setOpen] = React.useState(false); - - function handleClick() { - setOpen(true); - } - - function handleClose() { - setOpen(false); - } - - return ( -
- - I love snacks} - /> -
- ); -} - -export default FadeSnackbar; diff --git a/docs/src/pages/demos/snackbars/FadeSnackbar.tsx b/docs/src/pages/demos/snackbars/FadeSnackbar.tsx deleted file mode 100644 index e9f96f662fc1c0..00000000000000 --- a/docs/src/pages/demos/snackbars/FadeSnackbar.tsx +++ /dev/null @@ -1,33 +0,0 @@ -import React from 'react'; -import Button from '@material-ui/core/Button'; -import Snackbar from '@material-ui/core/Snackbar'; -import Fade from '@material-ui/core/Fade'; - -function FadeSnackbar() { - const [open, setOpen] = React.useState(false); - - function handleClick() { - setOpen(true); - } - - function handleClose() { - setOpen(false); - } - - return ( -
- - I love snacks} - /> -
- ); -} - -export default FadeSnackbar; diff --git a/docs/src/pages/demos/snackbars/LongTextSnackbar.js b/docs/src/pages/demos/snackbars/LongTextSnackbar.js index 840186019de595..c1fe3b4165caf7 100644 --- a/docs/src/pages/demos/snackbars/LongTextSnackbar.js +++ b/docs/src/pages/demos/snackbars/LongTextSnackbar.js @@ -11,6 +11,9 @@ const action = ( ); const styles = theme => ({ + root: { + maxWidth: 600, + }, snackbar: { margin: theme.spacing(1), }, @@ -20,7 +23,7 @@ function LongTextSnackbar(props) { const { classes } = props; return ( -
+
createStyles({ + root: { + maxWidth: 600, + }, snackbar: { margin: theme.spacing(1), }, @@ -23,7 +26,7 @@ function LongTextSnackbar(props: Props) { const { classes } = props; return ( -
+
; +} + +function TransitionsSnackbar() { + const [state, setState] = React.useState({ + open: false, + Transition: Fade, + }); + + const handleClick = Transition => () => { + setState({ + open: true, + Transition, + }); + }; + + function handleClose() { + setState({ + ...state, + open: false, + }); + } + + return ( +
+ + + I love snacks} + /> +
+ ); +} + +export default TransitionsSnackbar; diff --git a/docs/src/pages/demos/snackbars/TransitionsSnackbar.tsx b/docs/src/pages/demos/snackbars/TransitionsSnackbar.tsx new file mode 100644 index 00000000000000..096bcffb7ca1ab --- /dev/null +++ b/docs/src/pages/demos/snackbars/TransitionsSnackbar.tsx @@ -0,0 +1,49 @@ +import React from 'react'; +import Button from '@material-ui/core/Button'; +import Snackbar from '@material-ui/core/Snackbar'; +import Fade from '@material-ui/core/Fade'; +import Slide from '@material-ui/core/Slide'; +import { TransitionProps } from '@material-ui/core/transitions/transition'; + +function TransitionSlide(props: TransitionProps) { + return ; +} + +function TransitionsSnackbar() { + const [state, setState] = React.useState({ + open: false, + Transition: Fade, + }); + + const handleClick = (Transition: React.ComponentType) => () => { + setState({ + open: true, + Transition, + }); + }; + + function handleClose() { + setState({ + ...state, + open: false, + }); + } + + return ( +
+ + + I love snacks} + /> +
+ ); +} + +export default TransitionsSnackbar; diff --git a/docs/src/pages/demos/snackbars/snackbars.md b/docs/src/pages/demos/snackbars/snackbars.md index 95f9163fd91a58..c65a4e92f74904 100644 --- a/docs/src/pages/demos/snackbars/snackbars.md +++ b/docs/src/pages/demos/snackbars/snackbars.md @@ -52,11 +52,11 @@ Per [Google's guidelines](https://material.io/design/components/snackbars.html#s {{"demo": "pages/demos/snackbars/ConsecutiveSnackbars.js"}} -### Don't block the floating action button +### Snackbars and floating action buttons (FABs) -Move the floating action button vertically to accommodate the snackbar height. +Snackbars should appear above FABs (on mobile). -{{"demo": "pages/demos/snackbars/FabIntegrationSnackbar.js"}} +{{"demo": "pages/demos/snackbars/FabIntegrationSnackbar.js", "iframe": true}} ### Control Direction @@ -68,7 +68,7 @@ Change the direction of the transition. Slide is the default transition. Use a different transition. -{{"demo": "pages/demos/snackbars/FadeSnackbar.js"}} +{{"demo": "pages/demos/snackbars/TransitionsSnackbar.js"}} ## Complementary projects diff --git a/packages/material-ui/src/Snackbar/Snackbar.js b/packages/material-ui/src/Snackbar/Snackbar.js index bd5e151fe0cd60..b33c58328775ba 100644 --- a/packages/material-ui/src/Snackbar/Snackbar.js +++ b/packages/material-ui/src/Snackbar/Snackbar.js @@ -7,19 +7,18 @@ import { duration } from '../styles/transitions'; import ClickAwayListener from '../ClickAwayListener'; import { capitalize, createChainedFunction } from '../utils/helpers'; import withForwardedRef from '../utils/withForwardedRef'; -import Slide from '../Slide'; +import Grow from '../Grow'; import SnackbarContent from '../SnackbarContent'; export const styles = theme => { - const gutter = 24; - const top = { top: 0 }; - const bottom = { bottom: 0 }; + const top1 = { top: 8 }; + const bottom1 = { bottom: 8 }; const right = { justifyContent: 'flex-end' }; const left = { justifyContent: 'flex-start' }; - const topSpace = { top: gutter }; - const bottomSpace = { bottom: gutter }; - const rightSpace = { right: gutter }; - const leftSpace = { left: gutter }; + const top3 = { top: 24 }; + const bottom3 = { bottom: 24 }; + const right3 = { right: 24 }; + const left3 = { left: 24 }; const center = { left: '50%', right: 'auto', @@ -32,63 +31,65 @@ export const styles = theme => { zIndex: theme.zIndex.snackbar, position: 'fixed', display: 'flex', - left: 0, - right: 0, + left: 8, + right: 8, justifyContent: 'center', alignItems: 'center', }, /* Styles applied to the root element if `anchorOrigin={{ 'top', 'center' }}`. */ anchorOriginTopCenter: { - ...top, - [theme.breakpoints.up('md')]: { + ...top1, + [theme.breakpoints.up('sm')]: { + ...top3, ...center, }, }, /* Styles applied to the root element if `anchorOrigin={{ 'bottom', 'center' }}`. */ anchorOriginBottomCenter: { - ...bottom, - [theme.breakpoints.up('md')]: { + ...bottom1, + [theme.breakpoints.up('sm')]: { + ...bottom3, ...center, }, }, /* Styles applied to the root element if `anchorOrigin={{ 'top', 'right' }}`. */ anchorOriginTopRight: { - ...top, + ...top1, ...right, - [theme.breakpoints.up('md')]: { + [theme.breakpoints.up('sm')]: { left: 'auto', - ...topSpace, - ...rightSpace, + ...top3, + ...right3, }, }, /* Styles applied to the root element if `anchorOrigin={{ 'bottom', 'right' }}`. */ anchorOriginBottomRight: { - ...bottom, + ...bottom1, ...right, - [theme.breakpoints.up('md')]: { + [theme.breakpoints.up('sm')]: { left: 'auto', - ...bottomSpace, - ...rightSpace, + ...bottom3, + ...right3, }, }, /* Styles applied to the root element if `anchorOrigin={{ 'top', 'left' }}`. */ anchorOriginTopLeft: { - ...top, + ...top1, ...left, - [theme.breakpoints.up('md')]: { + [theme.breakpoints.up('sm')]: { right: 'auto', - ...topSpace, - ...leftSpace, + ...top3, + ...left3, }, }, /* Styles applied to the root element if `anchorOrigin={{ 'bottom', 'left' }}`. */ anchorOriginBottomLeft: { - ...bottom, + ...bottom1, ...left, - [theme.breakpoints.up('md')]: { + [theme.breakpoints.up('sm')]: { right: 'auto', - ...bottomSpace, - ...leftSpace, + ...bottom3, + ...left3, }, }, }; @@ -408,7 +409,7 @@ Snackbar.defaultProps = { horizontal: 'center', }, disableWindowBlurListener: false, - TransitionComponent: Slide, + TransitionComponent: Grow, transitionDuration: { enter: duration.enteringScreen, exit: duration.leavingScreen, diff --git a/packages/material-ui/src/Snackbar/Snackbar.test.js b/packages/material-ui/src/Snackbar/Snackbar.test.js index 01659025013873..19e5c8441d02e2 100644 --- a/packages/material-ui/src/Snackbar/Snackbar.test.js +++ b/packages/material-ui/src/Snackbar/Snackbar.test.js @@ -3,7 +3,7 @@ import { assert } from 'chai'; import { spy, useFakeTimers } from 'sinon'; import { createMount, describeConformance, getClasses } from '@material-ui/core/test-utils'; import Snackbar from './Snackbar'; -import Slide from '../Slide'; +import Grow from '../Grow'; describe('', () => { let mount; @@ -381,9 +381,9 @@ describe('', () => { }); describe('prop: TransitionComponent', () => { - it('should use a Slide by default', () => { + it('should use a Grow by default', () => { const wrapper = mount(); - assert.strictEqual(wrapper.find(Slide).exists(), true, 'should use a Slide by default'); + assert.strictEqual(wrapper.find(Grow).exists(), true); }); it('accepts a different component that handles the transition', () => { diff --git a/packages/material-ui/src/SnackbarContent/SnackbarContent.js b/packages/material-ui/src/SnackbarContent/SnackbarContent.js index e5b94060cfe8a1..a141b9bfac1213 100644 --- a/packages/material-ui/src/SnackbarContent/SnackbarContent.js +++ b/packages/material-ui/src/SnackbarContent/SnackbarContent.js @@ -20,14 +20,12 @@ export const styles = theme => { display: 'flex', alignItems: 'center', flexWrap: 'wrap', - padding: '6px 24px', - [theme.breakpoints.up('md')]: { + padding: '6px 16px', + borderRadius: theme.shape.borderRadius, + flexGrow: 1, + [theme.breakpoints.up('sm')]: { + flexGrow: 'initial', minWidth: 288, - maxWidth: 568, - borderRadius: theme.shape.borderRadius, - }, - [theme.breakpoints.down('sm')]: { - flexGrow: 1, }, }, /* Styles applied to the message wrapper element. */ @@ -39,7 +37,7 @@ export const styles = theme => { display: 'flex', alignItems: 'center', marginLeft: 'auto', - paddingLeft: 24, + paddingLeft: 16, marginRight: -8, }, }; diff --git a/pages/api/snackbar.md b/pages/api/snackbar.md index 8468e1d90a0b18..78e14f8d56aec2 100644 --- a/pages/api/snackbar.md +++ b/pages/api/snackbar.md @@ -37,7 +37,7 @@ import Snackbar from '@material-ui/core/Snackbar'; | onExiting | func |   | Callback fired when the transition is exiting. | | open | bool |   | If true, `Snackbar` is open. | | resumeHideDuration | number |   | The number of milliseconds to wait before dismissing after user interaction. If `autoHideDuration` property isn't specified, it does nothing. If `autoHideDuration` property is specified but `resumeHideDuration` isn't, we default to `autoHideDuration / 2` ms. | -| TransitionComponent | elementType | Slide | The component used for the transition. | +| TransitionComponent | elementType | Grow | The component used for the transition. | | transitionDuration | union: number |
 { enter?: number, exit?: number }
| { enter: duration.enteringScreen, exit: duration.leavingScreen,} | The duration for the transition, in milliseconds. You may specify a single timeout for all transitions, or individually with an object. | | TransitionProps | object |   | Properties applied to the `Transition` element. |