Skip to main content

Modal

Vielen Dank, dass Sie diese Komponente zur Umsetzung eines Modals verwenden wollen. Inzwischen ist das native <dialog> Element sehr gut unterstützt (), barrierefrei, einfach zu benutzen und performanter (da nativ), daher empfehlen wir dieses zu verwenden. Wenn Sie aufgrund von Abwärtskompatibilität, oder weil Sie die Modal-Komponente bereits eingebaut haben, die Dokumentation zu unserem KolModal suchen, finden Sie diese etwas weiter unten. Die Modal-Komponente wird in Version 2 noch zur Verfügung stehen.

Verwendung von dialog-Tag

Die Dokumentation des <dialog> finden Sie . Das Dialog-Element kann wie jedes andere HTML-Tag verwendet werden, alle Elemente innerhalb werden wie gewohnt dargestellt. Der Dialog ist standardmäßig nicht sichtbar, über das Setzen des Attributs open, oder über die Funktionen show() und showModal() wird er sichtbar. open und show() öffnen das Element mit position: absolute, während showModal() position: fixed setzt.

  • Beide Varianten haben eine max-width, die unter box-sizing: content-box der gesamten Bildschirmbreite entspricht (bzw des position Elters)
  • Die Modalvariante hat einen Hintergrund, der eine sanfte Abdunklung verursacht (unser Tipp: die Opacity der Hintergrundfarbe erhöhen), der über ::backdrop gestylt werden kann und Klickevents auf den Dialog weiterleitet.
  • Die Modalvariante ist in der Bildschirmmitte zentriert (via margin: auto, kann von CSS Resets überschrieben werden)

Mit Hilfe der Modal-Komponente können zusätzliche Informationen oder auch Eingabeformulare in einem Dialogfenster angezeigt werden. Ein offenes Modal kann via ESC geschlossen werden. Die Modal-Komponente ist standardmäßig versteckt. Sie wird i.d.R. erst nach Klick auf einen Button oder sonstigem Trigger angezeigt. Dabei wird der Hintergrund des Fensters deaktiviert und allein der Inhalt des Modal-Fensters ist aktiv.

Funktionsweise

Das Modal realisiert die Basis für barrierefreie Overlays und ermöglicht es beliebige HTML-Inhalte anzuzeigen. Beispielsweise wäre eine Dialog-Komponente eine Komposition aus einer Card-Komponente die in einer Modal-Komponente eingefügt wird.

Sobald ein Modal geöffnet wird, werden alle selektierbaren Elemente in der Webseite deaktiviert, außer die innerhalb des aktiven Modals.

Konstruktion

Code

<kol-modal id="test-modal" _label="Beschreibung zur Modalbox">
<kol-card _label="Vorgang löschen" style="background-color: bisque">
<div>
<p>Wollen Sie den Vorgang wirklich löschen?</p>
<kol-button className="close-modal" _label="Ok" _variant="primary"></kol-button>
<kol-button className="close-modal" _label="Abbrechen"></kol-button>
</div>
</kol-card>
</kol-modal>
<kol-button id="modal-open-button" _label="Modal öffnen"></kol-button>
<script>
const modal = document.querySelector('#test-modal');
const modalOpenButton = document.querySelector('#modal-open-button');
function openModal() {
modal._activeElement = modalOpenButton;
modal._open = true;
}
function closeModal() {
modal._activeElement = null;
}
document.querySelectorAll('.close-modal').forEach((b) => (b._on = { onClick: closeModal }));
modalOpenButton._on = { onClick: openModal };
</script>

Verwendung

Über das Attribut _width geben Sie die gewünschte Breite der Modalbox an. Sie wird in der gewählten Größe immer mittig auf dem Bildschirm angezeigt.

Da das Modal vom eigentlichen Modal entkoppelt ist, aber für eine teilweisen Sperrung der Inhalte sorgt. Muss es auch eine Möglichkeit bieten, das Schließen (Sperrung aufheben) aus dem Modal-Kontext zu ermöglichen.

Es wird empfohlen einen Close-Button oben rechts einzubauen.

Das Modal hat einen z-index von 100.

Best practices

  • Verwenden Sie die Modalbox, um weiterführende Informationen zu einem Thema anzuzeigen.
  • Verwenden Sie die Modalbox, um umfangreiche Inhalte optisch kompakter zu gestalten.
  • Vermeiden Sie es, wichtige Informationen wie z.B. rechtliche Themen, auf die Nutzer:innen reagieren müssen, in Modalboxen zu platzieren.

Anwendungsfälle

  • Nutzen Sie die Modalbox, als Erklärungshilfe zu einzelnen Eingabefeldern in Formularen.
  • Nutzen Sie die Modalbox, um ergänzende Informationen erst nach Anforderung durch die Nutzer:innen anzuzeigen.
  • Nutzen Sie die Modalbox, um ein Feedback zu Speichervorgängen oder ähnliches anzuzeigen, z.B. Vielen Dank für Ihre Rückmeldung nach Absenden eines Formulars.

Barrierefreiheit

Die optische Standardausgabe der Komponente ist auf die Umsetzung der Barrierefreiheit hin optimiert. Wenn Sie eigene Custom Styles verwenden, kann das zu einer Einschränkung der Barrierefreiheit führen.

Das Modal ist so realisiert, dass der Fokus darauf liegt, wenn es geöffnet wird. Elemente außerhalb des Modals sind dann nicht mehr fokussierbar.

Wird das Modal geschlossen, liegt der Fokus wieder auf dem Element, welches unter _activeElement angegeben wurde.

Bei der Realisierung dieser Funktionalität haben wir auf die Verwendung der CSS-Properties user-select und pointer-events verzichtet, um das Navigieren aus der Webseite in die Browser-Menü's weiterhin zu ermöglichen. Ebenfalls haben wir darauf verzichtet die Event-Propagation zu manipulieren.

Achten Sie für eine optimale Ausgabe der Modal-Komponente in Screenreadern darauf, das Attribut aria-label korrekt zu setzen.

Des Weiteren gibt es immer nur maximal ein aktives Modal, welches alle selektierbaren Elemente deaktiviert außer die innerhalb des eigenen Modals. Hierbei ist zu beachten, dass KoliBri nur Elemente deaktiviert die sich im Browser-Seitenbereich befinden. Das Fokussieren den Browser-Menü's ist weiterhin möglich.

Tastatursteuerung

TasteFunktion
TabBei geöffnetem Modal werden alle fokussierbaren Elemente der Reihenfolge nach angesprungen.
ESCSchließt das Modal.

Properties

PropertyAttributeDescriptionTypeDefault
_activeElement--Gibt die Referenz auf das auslösende HTML-Element an, wodurch das Modal geöffnet wurde.HTMLElement | null | undefinedundefined
_label (required)_labelDefines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).stringundefined
_on--Gibt die EventCallback-Function für das Schließen des Modals an.undefined | ({ onClose?: (() => void) | undefined; })undefined
_width_widthDefines the width of the modal. (max-width: 100%)string | undefined'100%'

Slots

SlotDescription
Der Inhalt des Modals.