## MessageBox Un conjunto de cajas modales simulando un sistema de message box, principalmente para alertar informacion, confirmar operaciones y mostrar mensajes de aviso. :::tip Por diseño los message box nos proveen de simulaciones de sistemas como los componentes `alert`, `confirm` y `prompt`,entonces su contenido debería ser simple. para contenido mas complejo, por favor utilize el componente Dialog. ::: ### Alert Alert interrumpe las operaciones realizadas hasta que el usuario confirme la alerta. :::demo Desplegar una alerta utilizando el metodo `$alert`. Simula el sistema `alert`, y no puede ser cerrado al presionar la tecla ESC o al dar click fuera de la caja. En este ejemplo, dos parametros son recibidos `message` y `title`. Vale la pena mencionar que cuando la caja es cerrada, regresa un objeto `Promise` para su procesamiento posteriormente. Si no estas seguro si el navegador soporta `Promise`, deberias importar una libreria de terceros de polyfill o utilizar callbacks. ```html ``` ::: ### Confirm Confirm es utilizado para preguntar al usuario y recibir una confirmacion. :::demo Llamando al metodo `$confirm` para abrir el componente confirm, y simula el sistema `confirm`. Tambien podemos personalizar a gran medida el componente Message Box al mandar un tercer atributo llamado `options` que es literalmente un objeto. El atributo `type` indica el tipo de mensaje, y su valor puede ser `success`, `error`, `info` y `warning`. Se debe tener en cuenta que el segundo atributo `title` debe ser de tipo `string`, y si es de tipo `object`, sera manejado como el atributo `options`. Aqui utilizamos `Promise` para manejar posteriormente el proceso. ```html ``` ::: ### Prompt Prompt es utilizado cuando se requiere entrada de informacion del usuario. :::demo Llamando al metodo `$prompt` desplegamos el componente prompt, y simula el sistema `prompt`.Puedes utilizar el parametro `inputPattern` para especificar tu propio patron RegExp. Utiliza el parametro `inputValidator` para especificar el metodo de validacion, y debería regresar un valor de tipo `Boolean` o `String`. Al regresar `false` o `String` significa que la validacion a fallado, y la cadena regresada se usara como `inputErrorMessage`. Ademas, puedes perzonalizar el atributo placeholder del input box con el parametro `inputPlaceholder`. ```html ``` ::: ### Personalización Puede ser personalizado para mostrar diversos contenidos. :::demo Los tres metodos mencionados anteriormente son un rempaquetado del metodo `$msgbox`. En este ejemplo se realiza una llamada al metodo `$msgbox` directamente utilizando el atributo `showCancelButton`, el cual es utilizado para indicar si el boton cancelar es mostrado en pantalla. Ademas podemos utilizar el atributo `cancelButtonClass` para agregar un estilo personalizado y el atributo `cancelButtonText` para personalizar el texto del boton (el boton de confirmacion tambien cuenta con estos campos, y podra encontrar una lista completa de estos atributos al final de esta documentacion). Este ejemplo tambien utiliza el atributo `beforeClose`. Es un metodo que es disparado cuando una instancia del componente MessageBox es cerrada, y su ejecucion detendra el cierre de la instancia. Tiene tres parametros: `action`, `instance` y `done`. Al utilizarla te permite manipular la instancia antes de que sea cerrada, e.g. activando `loading` para el boton de confirmacion; puede invocar el metodo `done` para cerrar la instancia del componente MessageBox (si el metodo `done` no es llamado dentro del atributo `beforeClose`, la instancia no podra cerrarse). ```html ``` ::: :::tip El contenido de MessageBox puede ser `VNode`, permitiéndonos pasar componentes personalizados. Al abrir el MessageBox, Vue compara el nuevo `VNode` con el viejo `VNode`, y luego averigua cómo actualizar eficientemente la interfaz de usuario, de modo que es posible que los componentes no se vuelvan a procesar completamente ([#8931](https://github.com/ElemeFE/element/issues/8931)). En este caso, se puede añadir una clave única a `VNode` cada vez que se abre MessageBox: [ejemplo](https://jsfiddle.net/zhiyang/ezmhq2ef). ::: ### Utiliza cadenas HTML `message` soporta cadenas HTML. :::demo Establezca el valor de `dangerouslyUseHTMLString` a true y `message` sera tratado como una cadena HTML. ```html ``` ::: :::warning Aunque la propiedad `message` soporta cadenas HTML, realizar arbitrariamente render dinamico de HTML en nuestro sitio web puede ser muy peligroso ya que puede conducir facilmente a [XSS attacks](https://en.wikipedia.org/wiki/Cross-site_scripting). Entonces cuando `dangerouslyUseHTMLString` esta activada, asegurece que el contendio de `message` sea de confianza, y **nunca** asignar `message` a contenido generado por el usuario. ::: ### Distinguir entre cancelar y cerrar En algunos casos, hacer clic en el botón Cancelar y en el botón Cerrar puede tener diferentes significados. :::demo Por defecto, los parámetros de `Promise's reject callback` y `callback` son `cancel` cuando el usuario cancela (haciendo clic en el botón de cancelación) y cierra (haciendo clic en el botón de cerrar o en la capa de máscara, pulsando la tecla ESC) el MessageBox. Si `distinguishCancelAndClose` está ajustado a `true`, los parámetros de las dos operaciones anteriores son `cancel` y `close` respectivamente. ```html ``` ::: ### Centered content El contenido del componente MessageBox puede ser centrado. :::demo Establecer `center` a `true` centrara el contenido ```html ``` ::: ### Metodos Globales Si Element fue importado completamente, agregara los siguientes metodos globales para Vue.prototype: `$msgbox`, `$alert`, `$confirm` y `$prompt`. Asi que en una instancia de Vue puedes llamar el metodo `MessageBox` como lo que hicimos en esta pagina. Los parametros son: - `$msgbox(options)` - `$alert(message, title, options)` or `$alert(message, options)` - `$confirm(message, title, options)` or `$confirm(message, options)` - `$prompt(message, title, options)` or `$prompt(message, options)` ### Importación local Si prefieres importar `MessageBox` cuando lo necesites (on demand): ```javascript import { MessageBox } from 'element-ui'; ``` Los metodos correspondientes: `MessageBox`, `MessageBox.alert`, `MessageBox.confirm` y `MessageBox.prompt`. Los parametros son los mismos que los anteriores. ### Opciones | Atributo | Descripción | Tipo | Valores Permitidos | Por defecto | | ------------------------ | ---------------------------------------- | ---------------------------------------- | -------------------------------- | ---------------------------------------- | | title | titulo del componente MessageBox | string | — | — | | message | contenido del componente MessageBox | string | — | — | | dangerouslyUseHTMLString | utilizado para que `message` sea tratado como una cadena HTML | boolean | — | false | | type | tipo de mensaje , utilizado para mostrar el icono | string | success / info / warning / error | — | | iconClass | clase personalizada para el icono, sobreescribe `type` | string | — | — | | customClass | nombre de la clase personzalida para el componente MessageBox | string | — | — | | callback | MessageBox callback al cerrar si no desea utilizar Promise | function(action), donde la accion puede ser 'confirm', 'cancel' o 'close', e `instance` es la instancia del componente MessageBox. Puedes acceder a los metodos y atributos de esa instancia | — | — | | beforeClose | callback llamado antes de cerrar el componente MessageBox, y previene que el componente MessageBox se cierre | function(action, instance, done), donde `action` pueden ser 'confirm', 'cancel' o 'close'; `instance` es la instancia del componente MessageBox, Puedes acceder a los metodos y atributos de esa instancia; `done` es para cerrar la instancia | — | — | | distinguishCancelAndClose | si se debe distinguir entre cancelar y cerrar | boolean | — | false | | lockScroll | utilizado para bloquear el desplazamiento del contenido del MessageBox prompts | boolean | — | true | | showCancelButton | utlizado para mostrar un boton cancelar | boolean | — | false (true cuando es llamado con confirm y prompt) | | showConfirmButton | utlizado para mostrar un boton confirmar | boolean | — | true | | cancelButtonText | contenido de texto del boton cancelar | string | — | Cancel | | confirmButtonText | contenido de texto del boton confirmar | string | — | OK | | cancelButtonClass | nombre de la clase personalizada del boton cancelar | string | — | — | | confirmButtonClass | nombre de la clase personalizada del boton confirmar | string | — | — | | closeOnClickModal | utilizado para que que el componenteMessageBox pueda ser cerrado al dar click en la mascara | boolean | — | true (false cuando es llamado con alert) | | closeOnPressEscape | utilizado para que que el componenteMessageBox pueda ser cerrado al presionar la tecla ESC | boolean | — | true (false cuando es llamado con alert) | | closeOnHashChange | utilizado para cerra el componente MessageBox cuando hash cambie | boolean | — | true | | showInput | utilizado para mostrar el componente input | boolean | — | false (true cuando es llamado con prompt) | | inputPlaceholder | placeholder para el componente input | string | — | — | | inputType | tipo del componente input | string | — | text | | inputValue | valor inicial del componente input | string | — | — | | inputPattern | regexp del componente input | regexp | — | — | | inputValidator | funcion de validacion del componente input. Debe regresar un valor de tipo boolean o string. Si regresa un valor tipo string, sera asignado a inputErrorMessage | function | — | — | | inputErrorMessage | mensaje de error cuando la validacion falla | string | — | Illegal input | | center | utilizado para alinear el contenido al centro | boolean | — | false | | roundButton | utilizado para redondear el boton | boolean | — | false |