import Component from 'flarum/Component'; import Alert from 'flarum/components/Alert'; import Button from 'flarum/components/Button'; /** * The `Modal` component displays a modal dialog, wrapped in a form. Subclasses * should implement the `className`, `title`, and `content` methods. * * @abstract */ export default class Modal extends Component { init() { /** * An alert component to show below the header. * * @type {Alert} */ this.alert = null; } view() { if (this.alert) { this.alert.props.dismissible = false; } return (
{this.isDismissible() ? (
{Button.component({ icon: 'times', onclick: this.hide.bind(this), className: 'Button Button--icon Button--link' })}
) : ''}

{this.title()}

{alert ?
{this.alert}
: ''} {this.content()}
); } /** * Determine whether or not the modal should be dismissible via an 'x' button. * * @return {Boolean} */ isDismissible() { return true; } /** * Get the class name to apply to the modal. * * @return {String} * @abstract */ className() { } /** * Get the title of the modal dialog. * * @return {String} * @abstract */ title() { } /** * Get the content of the modal. * * @return {VirtualElement} * @abstract */ content() { } /** * Handle the modal form's submit event. * * @param {Event} e */ onsubmit() { } /** * Focus on the first input when the modal is ready to be used. */ onready() { this.$('form').find('input, select, textarea').first().focus().select(); } onhide() { } /** * Hide the modal. */ hide() { app.modal.close(); } /** * Stop loading. */ loaded() { this.loading = false; m.redraw(); } /** * Show an alert describing an error returned from the API, and give focus to * the first relevant field. * * @param {RequestError} error */ onerror(error) { this.alert = error.alert; m.redraw(); if (error.status === 422 && error.response.errors) { this.$('form [name=' + error.response.errors[0].source.pointer.replace('/data/attributes/', '') + ']').select(); } else { this.onready(); } } }