Esse pacote oferece funções auxiliares para disparar notificações em snackbar, usando o componente Snackbar. A base da ideia é encapsular toda a regra de estados em uma API de Contexto do React, para ser usada em qualquer lugar.
Use o link do próprio repositório para instalar o modulo, no seu projeto, execute o seguinte comando:
npm install mui-snackbar-utils
No seu projeto react, após a instalação, basta usar:
import { SnackbarProvider, useSnackbar } from 'mui-snackbar-utils';
Inicie o projeto e acesse a pagina inicial que contém exemplos.
npm run dev
Abaixo a lista de funções disponíveis, exemplos completos voce pode encontrar no arquivo Preview.jsx
.
Dispara um snackbar com uma mensagem, caso envie um valor de 'severity' será disparado um modelo de alerta, e em 'options' você pode enviar qualquer propriedade da lib oficial do snackbar.
Você também pode enviar { 'alertProps': { ... } } dentro de 'options' para atribuir propriedades ao component Alert
function Test() {
const { setSnackbar } = useSnackbar();
const handleClick = (severity) => {
setSnackbar("Hello World Message", severity);
};
return (
<button onClick={() => setSnackbar("Hello world message")}>
Show message
</button>
<button onClick={() => setSnackbar("Hey a success message", "success")}>
Show success message
</button>
<button onClick={() => setSnackbar("On top right message with info alert", "info", {
anchorOrigin: { vertical: "top", horizontal: "right" }
})}>
Show a top right message info
</button>
);
}
Você também pode definir opções "globais" para o contexto via ´provider´
function Test() {
const { setSnackbar } = useSnackbar();
const handleClick = (severity) => {
setSnackbar("Hello World Message", severity);
};
return (
<button onClick={() => setSnackbar("Hello world message")}>
Show message
</button>
)
};
function App(){
return (
<SnackbarProvider options={{
anchorOrigin: {
vertical: "bottom",
horizontal: "right"
},
alertProps: {
variant: "outlined"
}
}}>
<Test />
</SnackbarProvider>
)
}
Qualquer chamada de
setSnackbar
terá as opções definidas no provider.
Esse modulo foi construído com base no artigo abaixo que mostra como distribuir seu projeto como modulo npm.