2021-10-31 06:31:34 +08:00
|
|
|
import Component from '../Component';
|
|
|
|
import { AlertAttrs } from './Alert';
|
|
|
|
import type Mithril from 'mithril';
|
|
|
|
import type ModalManagerState from '../states/ModalManagerState';
|
|
|
|
import type RequestError from '../utils/RequestError';
|
|
|
|
import type ModalManager from './ModalManager';
|
|
|
|
interface IInternalModalAttrs {
|
|
|
|
state: ModalManagerState;
|
|
|
|
animateShow: ModalManager['animateShow'];
|
|
|
|
animateHide: ModalManager['animateHide'];
|
|
|
|
}
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
|
|
|
* The `Modal` component displays a modal dialog, wrapped in a form. Subclasses
|
|
|
|
* should implement the `className`, `title`, and `content` methods.
|
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
export default abstract class Modal<ModalAttrs = {}> extends Component<ModalAttrs & IInternalModalAttrs> {
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
|
|
|
* Determine whether or not the modal should be dismissible via an 'x' button.
|
|
|
|
*/
|
2021-11-12 03:21:56 +08:00
|
|
|
static readonly isDismissible: boolean;
|
2021-10-31 06:31:34 +08:00
|
|
|
protected loading: boolean;
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
|
|
|
* Attributes for an alert component to show below the header.
|
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
alertAttrs: AlertAttrs;
|
|
|
|
oninit(vnode: Mithril.VnodeDOM<ModalAttrs & IInternalModalAttrs, this>): void;
|
|
|
|
oncreate(vnode: Mithril.VnodeDOM<ModalAttrs & IInternalModalAttrs, this>): void;
|
|
|
|
onbeforeremove(vnode: Mithril.VnodeDOM<ModalAttrs & IInternalModalAttrs, this>): Promise<void> | void;
|
|
|
|
view(): JSX.Element;
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
|
|
|
* Get the class name to apply to the modal.
|
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
abstract className(): string;
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
|
|
|
* Get the title of the modal dialog.
|
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
abstract title(): string;
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
|
|
|
* Get the content of the modal.
|
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
abstract content(): Mithril.Children;
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
|
|
|
* Handle the modal form's submit event.
|
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
abstract onsubmit(e: Event): void;
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
2021-10-31 06:31:34 +08:00
|
|
|
* Callback executed when the modal is shown and ready to be interacted with.
|
|
|
|
*
|
|
|
|
* @remark Focuses the first input in the modal.
|
2021-05-13 07:29:46 +08:00
|
|
|
*/
|
|
|
|
onready(): void;
|
|
|
|
/**
|
2021-10-31 06:31:34 +08:00
|
|
|
* Hides the modal.
|
2021-05-13 07:29:46 +08:00
|
|
|
*/
|
|
|
|
hide(): void;
|
|
|
|
/**
|
2021-10-31 06:31:34 +08:00
|
|
|
* Sets `loading` to false and triggers a redraw.
|
2021-05-13 07:29:46 +08:00
|
|
|
*/
|
|
|
|
loaded(): void;
|
|
|
|
/**
|
2021-10-31 06:31:34 +08:00
|
|
|
* Shows an alert describing an error returned from the API, and gives focus to
|
|
|
|
* the first relevant field involved in the error.
|
2021-05-13 07:29:46 +08:00
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
onerror(error: RequestError): void;
|
2021-05-13 07:29:46 +08:00
|
|
|
}
|
2021-10-31 06:31:34 +08:00
|
|
|
export {};
|