Notistack v2
primarily focuses on flexibility, scalibity and customisation. There has been numerous issues and pull requests
on the repository asking support for customising snackbars more easily.
So far, customisation was only possible by overriding the existing styles, but this is not always enough. There is only so
much you can do by overriding styles. Since we can't cover everyone's requirements natively on notistack, in v2
, we give
you the tools to build your own snackbars. This is achieved through Components
prop.
-
content
prop is still supported but marked as deprecated and it will be removed in future releases. If you find yourself using this prop quite often, consider defining your own custom variant/content using Components props. -
Drop
ariaAttributes
from props. If you need to pass aria-attributes, use a custom component. -
HTML attributes applied to Snackbar root component should be passed inside
SnackbarProps
prop.
<SnackbarProvider
- data-test="test"
+ SnackbarProps={{
+ 'data-test': 'test',
+ }}
>
</SnackbarProvider>
enqueueSnackbar('message', {
- 'data-test': 'test',
+ SnackbarProps: {
+ 'data-test': 'test',
+ },
})
-
Drop support for
resumeHideDuration
,onEntering
andonExisting
transition callbacks due to the fact that they are rarely used. Get in touch if this decision affects you to potentially bring them back to life. -
onClose
won't be called withreason: 'clickaway'
anymore. Get in touch if you need to detect clickaway's to potentially bring them back to life. -
Drop Customisation through
classes.variant(Success|Error|Info|Warning)
. To customise snackbars according to their variant, use a custom component. This example demonstrates how this is done. -
Any customisation through Material-UI theme is not applied to the elements. This would also mean toggling theme
mode
to Dark/Light would not affect the appearance of snackbars. You can easily use a custom component to have full control over your snackbars.This example
demonstrates how your snackbars can react to change of theme mode. -
Drop support for
withSnackbar
Higher-order component (HOC). Consequently, exported typeWithSnackbarProps
was kept in type declerations for backwards compatibility and after over a year, it has been now deleted and you should useProviderContext
type instead. You have two options to migrate your code:- Option 1: Migrate your code to be functional component and use
useSnackbar
. - Option 2: Remove
withSnackbar
and import the function(s) you need directly fromnotistack
:
- Option 1: Migrate your code to be functional component and use
- import { withSnackbar } from 'notistack'
+ import { enqueueSnackbar, closeSnackbar } from 'notistack'
class MyButton extends React.Component {
render() {
- const { enqueueSnackbar } = this.props
}
}
- export default withSnackbar(MyButton)
+ export default MyButton
You can now define your own variant
s and show entirely customsied snackbars. Your custom component accepts all props passed to enqueueSnackbar
or SnackbarProvider
, so you have full control over it. On top of that, you'll be able pass additional options in options parameter of `enqueueSnackbar. For Typescript users, be sure to follow these additional steps to make the typings work. Example usage:
<SnackbarProvider
Components={{
success: MyCustomSuccessNotification,
reportComplete: ReportComplete,
}}
>
</SnackbarProvider>
interface ReportCompleteProps extends CustomContentProps {
allowDownload: boolean;
}
const ReportComplete = React.forwardRef((props: ReportCompleteProps, ref) => {
const {
// You have access to notistack props, options 👇🏼
variant,
message
// as well as your own custom props 👇🏼
allowDownload,
} = props;
//
})
enqueueSnackbar('Your report is ready to download', {
variant: 'reportComplete',
persist: true,
allowDownload: true, // <-- pass any additional options
})