mirror of
https://github.com/ionic-team/ionic-framework.git
synced 2025-08-17 02:31:34 +08:00
55 lines
1.4 KiB
TypeScript
55 lines
1.4 KiB
TypeScript
import { Component, Listen, Method, Prop } from '@stencil/core';
|
|
import { ToastOptions } from '../../interface';
|
|
import { OverlayController, createOverlay, dismissOverlay, getTopOverlay, removeLastOverlay } from '../../utils/overlays';
|
|
|
|
|
|
@Component({
|
|
tag: 'ion-toast-controller'
|
|
})
|
|
export class ToastController implements OverlayController {
|
|
|
|
private toasts = new Map<number, HTMLIonToastElement>();
|
|
|
|
@Prop({ context: 'document' }) doc!: Document;
|
|
|
|
@Listen('body:ionToastWillPresent')
|
|
protected toastWillPresent(ev: any) {
|
|
this.toasts.set(ev.target.overlayId, ev.target);
|
|
}
|
|
|
|
@Listen('body:ionToastWillDismiss')
|
|
@Listen('body:ionToastDidUnload')
|
|
protected toastWillDismiss(ev: any) {
|
|
this.toasts.delete(ev.target.overlayId);
|
|
}
|
|
|
|
@Listen('body:keyup.escape')
|
|
protected escapeKeyUp() {
|
|
removeLastOverlay(this.toasts);
|
|
}
|
|
|
|
/**
|
|
* Create a toast overlay with toast options.
|
|
*/
|
|
@Method()
|
|
create(opts?: ToastOptions): Promise<HTMLIonToastElement | null> {
|
|
return createOverlay(this.doc.createElement('ion-toast'), opts);
|
|
}
|
|
|
|
/**
|
|
* Dismiss the open toast overlay.
|
|
*/
|
|
@Method()
|
|
dismiss(data?: any, role?: string, toastId = -1) {
|
|
return dismissOverlay(data, role, this.toasts, toastId);
|
|
}
|
|
|
|
/**
|
|
* Get the most recently opened toast overlay.
|
|
*/
|
|
@Method()
|
|
getTop(): HTMLIonToastElement {
|
|
return getTopOverlay(this.toasts);
|
|
}
|
|
}
|