Toaster
Synonyme: Notification, Snackbar
Mit dem Toast-Service geben Sie ein optisches Feedback an die Nutzer:innen. Sie wird am Kopf des Browserfenster angezeigt, bis sie geschlossen wird. Werden mehrere Toasts geöffnet, ohne das die bisherigen geschlossen wurden, so werden diese untereinander angezeigt.
Konstruktion
Die Toast-Komponenten werden nicht direkt verwendet, sondern immer über den ToasterService konstruiert.
Code
import { ToasterService } from '@public-ui/components';
// Get the toaster instance for the current HTML document.
const toaster = ToasterService.getInstance(document, {
defaultAlertType: 'msg', // Standard: 'card'
});
// Enqueue a new toast to the toaster to display:
toaster.enqueue({
label: 'This is the title',
description: 'Magna eu sit adipisicing cillum amet esse in aute quis in dolore.',
type: 'info',
variant: 'msg', // Standard: 'card'
});
Weitere Service-Methoden
closeAll
: Schließt alle Toastsdispose
: Entfernt den Toast Container. Die Toaster-Instanz kann nicht weiter genutzt werden.
Verwendung
Überschrift
Verwenden Sie das Attribut _label
, um die Überschrift des Toasts zu bestimmen.
Inhalt
Verwenden Sie das Attribut _description
, um den Text-Inhalt des Toasts zu bestimmen.
Alternativ zur statischen Description können Sie über das Attribut _render
eine eigene Render-Funktion definieren. Diese wird mit einer Referenz zum HTMLElement der Toast-Komponente aufgerufen. Zudem wird auch ein Objekt übergeben, das eine close
-Funktion zum Schließen des Toasts bereitstellt.
const closeToast = toaster.enqueue({
render: (element: HTMLElement, { close }) => {
element.textContent = 'Mein Inhalt';
const customCloseButton = document.createElement('button');
customCloseButton.textContent = 'Toast schließen';
element.appendChild(customCloseButton);
customCloseButton.addEventListener('click', close, { once: true });
},
});
/* Optional: Toast wieder schließen mit `closeToast()` */
Anzeigetyp des Toast
Verwenden Sie das Attribut _type
, um den Typ des Toasts festzulegen. Mögliche Werte sind:
default
error
info
success
warning
Methods
closeAll
closeAll(immediate?: boolean) => Promise<void>
Parameters
Name | Type | Description |
---|---|---|
immediate | boolean |
Returns
Type: Promise<void>
enqueue(toast: Toast) => Promise<() => void>
Parameters
Name | Type | Description |
---|---|---|
toast | { description?: string | undefined; render?: ToastRenderFunction | undefined; label: string; type: "error" | "default" | "info" | "success" | "warning"; alertVariant?: "card" | "msg" | undefined; variant?: "card" | "msg" | undefined; } |
Returns
Type: Promise<() => void>