Esse pacote oferece funções auxiliares para apresentar caixas de diálogos, usando o componente Mui Dialog
Use o link do próprio repositório para instalar o modulo, no seu projeto, execute o seguinte comando:
npm install mui-dialog-utils
No seu projeto react, após a instalação, basta usar:
import { DialogProvider, useDialog } from 'mui-dialog-utils';
ou
import useDialog from 'mui-dialog-utils/useDialog';
Inicie o projeto com 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
.
Durante os teste, basta clicar fora do dialogo para fecha-lo.
Apresenta um modal básico com uma mensagem e um botão de confirmação.
function Test() {
const { setAlert } = useDialog();
const handleClick = () => {
setAlert("Hello World Message", {
// ... Dialog Props
fullWidth: true,
maxWidth: "xs"
})
.finally(() => {
console.log("Dialog close triggered!");
})
};
return (
<button onClick={handleClick}>Show Alert</button>
);
}
Observe que este retorna uma
Promise
que é resolvida a medida que o cliente fecha o dialogo.
Apresenta um modal básico com um titulo, uma mensagem, botão de confirmação e outro para cancelamento.
function Test() {
const { setConfirm } = useDialog();
const handleClick = () => {
setConfirm("Title Are You Sure?", "Hello World Message Confirmation", {
// ... Dialog Props
fullWidth: true,
maxWidth: "xs"
})
.then((result) => {
if(result)
console.log("Confirmation triggered");
else
console.log("Cancellation or close triggered");
});
};
return (
<button onClick={handleClick}>Show Confirm</button>
);
}
Observe que este retorna uma
Promise
que é resolvida a medida que o cliente interage com as ações de confirmação ou cancelamento do dialogo.
Apresenta um modal básico de conteúdo aberto, onde voce pode passar seu próprio componente.
function MyComponent({ param }){
return <div>My Component Param {param}</div>
};
function Test() {
const { setDialog } = useDialog();
const handleClick = () => {
setDialog(<MyComponent param={123} />, {
// ... Dialog Props
fullWidth: true,
maxWidth: "xs",
// ... Triggered when modal is closing by outside click
onClose: () => setDialog(false)
});
};
return (
<button onClick={handleClick}>Show Dialog</button>
);
}
Este não retorna uma
Promise
e é necessário que voce envie o callback de fechamento do dialogo, passandosetDialog(false)
para fechar o dialogo mais recente.*
Essa é uma das formas de utilização do dialogo, sobrepor um novo dialogo acima de um já existente, como proposto neste exemplo de modal
, é possível aninhar os diálogos inserindo o proximo dialogo dentro da estrutura do primeiro.
Este modulo foi encapsulado dentro da estrutura de Context Provider
do react, de forma que facilita a utilização das funções sem a necessidade de re-implementar a construção dos modais a cada pagina ou componente que precisa utiliza-lo. Além disso, pensando na estrutura de aninhamento de diálogos, cada contexto de dialogo faz o empilhamento
de diálogos a medida que os métodos setAlert
, setConfirm
e setDialog
são chamados, e a renderização deles é estruturada de uma forma que o proximo dialogo é declarado dentro do anterior, permitindo a renderização de diálogos sobrepostos respeitando a estrutura proposta pela lib do mui
.
Acesse o arquivo DialogProvider.jsx para mais detalhes de como está sendo feito o
empilhamento
.
É importante ter em mente que para o conteúdo do seu componente que está sendo carregado em uma caixa de dialogo tenha acesso ao contexto de um provedor terceiro, é necessário que o contexto do dialogo esteja dentro da hierarquia, vide exemplos no arquivo Preview.jsx a partir da linha 92.
Esse modulo foi construído com base no artigo abaixo que mostra como distribuir seu projeto como modulo npm.