2021-10-31 06:31:34 +08:00
|
|
|
import Modal from '../components/Modal';
|
|
|
|
/**
|
|
|
|
* Class used to manage modal state.
|
|
|
|
*
|
|
|
|
* Accessible on the `app` object via `app.modal` property.
|
|
|
|
*/
|
2021-05-13 07:29:46 +08:00
|
|
|
export default class ModalManagerState {
|
|
|
|
/**
|
2021-10-31 06:31:34 +08:00
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
modal: null | {
|
|
|
|
componentClass: typeof Modal;
|
|
|
|
attrs?: Record<string, unknown>;
|
|
|
|
};
|
|
|
|
private closeTimeout?;
|
|
|
|
/**
|
|
|
|
* Shows a modal dialog.
|
|
|
|
*
|
|
|
|
* If a modal is already open, the existing one will close and the new modal will replace it.
|
2021-05-13 07:29:46 +08:00
|
|
|
*
|
2021-10-31 06:31:34 +08:00
|
|
|
* @example <caption>Show a modal</caption>
|
|
|
|
* app.modal.show(MyCoolModal, { attr: 'value' });
|
|
|
|
*
|
|
|
|
* @example <caption>Show a modal from a lifecycle method (`oncreate`, `view`, etc.)</caption>
|
|
|
|
* // This "hack" is needed due to quirks with nested redraws in Mithril.
|
|
|
|
* setTimeout(() => app.modal.show(MyCoolModal, { attr: 'value' }), 0);
|
|
|
|
*/
|
|
|
|
show(componentClass: typeof Modal, attrs?: Record<string, unknown>): void;
|
|
|
|
/**
|
|
|
|
* Closes the currently open dialog, if one is open.
|
2021-05-13 07:29:46 +08:00
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
close(): void;
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
2021-10-31 06:31:34 +08:00
|
|
|
* Checks if a modal is currently open.
|
2021-05-13 07:29:46 +08:00
|
|
|
*
|
2021-10-31 06:31:34 +08:00
|
|
|
* @returns `true` if a modal dialog is currently open, otherwise `false`.
|
2021-05-13 07:29:46 +08:00
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
isModalOpen(): boolean;
|
2021-05-13 07:29:46 +08:00
|
|
|
}
|