Verwende ein Modal, um z. B. ...
-
einfache Dialoge wie Abfragen oder kurze Anlege-Prozesse anzuzeigen.
-
kurze Bearbeitungsmöglichkeiten darzustellen.
-
Inhalte anzuzeigen, die kein Scrollen erfordern und für die die Breite des Modals ausreicht.
Verwende <Modal />
, um ein Modal darzustellen. Da ein Modal in der Regel nur
durch eine Aktion des Nutzers erscheint, wird ein <ModalTrigger />
in
Kombination z. B. einem <Button />
benötigt.
import Modal, { ModalTrigger, } from "@mittwald/flow-react-components/Modal"; import Content from "@mittwald/flow-react-components/Content"; import Text from "@mittwald/flow-react-components/Text"; import TextField from "@mittwald/flow-react-components/TextField"; import Label from "@mittwald/flow-react-components/Label"; import ActionGroup from "@mittwald/flow-react-components/ActionGroup"; import Button from "@mittwald/flow-react-components/Button"; import Heading from "@mittwald/flow-react-components/Heading"; import Action from "@mittwald/flow-react-components/Action"; import { sleepLong } from "@/content/03-components/actions/action/examples/lib"; import Section from "@mittwald/flow-react-components/Section"; <ModalTrigger> <Button>Modal öffnen</Button> <Modal> <Heading>Organisation anlegen</Heading> <Content> <Section> <Text> Eine Organisation kannst du dir wie ein Unternehmen vorstellen. An diesem Ort verwaltest du deine Mitarbeiter, Zahlungsmodalitäten und kannst deine Rechnungen einsehen. </Text> <TextField isRequired> <Label>Organisationsname</Label> </TextField> </Section> </Content> <ActionGroup> <Action closeOverlay="Modal"> <Action action={sleepLong}> <Button color="accent"> Organisation anlegen </Button> </Action> <Button variant="soft" color="secondary"> Abbrechen </Button> </Action> </ActionGroup> </Modal> </ModalTrigger>
Neben der klassischen Darstellung lässt sich das Modal auch als OffCanvas öffnen.
import Modal, { ModalTrigger, } from "@mittwald/flow-react-components/Modal"; import Content from "@mittwald/flow-react-components/Content"; import Text from "@mittwald/flow-react-components/Text"; import TextField from "@mittwald/flow-react-components/TextField"; import Label from "@mittwald/flow-react-components/Label"; import ActionGroup from "@mittwald/flow-react-components/ActionGroup"; import Button from "@mittwald/flow-react-components/Button"; import Heading from "@mittwald/flow-react-components/Heading"; import Action from "@mittwald/flow-react-components/Action"; import { sleepLong } from "@/content/03-components/actions/action/examples/lib"; import Section from "@mittwald/flow-react-components/Section"; <ModalTrigger> <Button>OffCanvas öffnen</Button> <Modal offCanvas> <Heading>Organisation anlegen</Heading> <Content> <Section> <Text> Eine Organisation kannst du dir wie ein Unternehmen vorstellen. An diesem Ort verwaltest du deine Mitarbeiter, Zahlungsmodalitäten und kannst deine Rechnungen einsehen. </Text> <TextField> <Label>Organisationsname</Label> </TextField> </Section> </Content> <ActionGroup> <Action closeOverlay="Modal"> <Action action={sleepLong}> <Button color="accent"> Organisation anlegen </Button> </Action> <Button variant="soft" color="secondary"> Abbrechen </Button> </Action> </ActionGroup> </Modal> </ModalTrigger>
Das Modal gibt es in zwei Standardgrößen: S und M. Beide Größen sind sowohl als klassisches Modal als auch in der OffCanvas-Variante verfügbar. In der OffCanvas-Darstellung kannst du außerdem eine individuelle Größe je nach Anwendungsfall festlegen.
import Modal, { ModalTrigger, } from "@mittwald/flow-react-components/Modal"; import Content from "@mittwald/flow-react-components/Content"; import Text from "@mittwald/flow-react-components/Text"; import TextField from "@mittwald/flow-react-components/TextField"; import Label from "@mittwald/flow-react-components/Label"; import ActionGroup from "@mittwald/flow-react-components/ActionGroup"; import Button from "@mittwald/flow-react-components/Button"; import Heading from "@mittwald/flow-react-components/Heading"; import Action from "@mittwald/flow-react-components/Action"; import Option from "@mittwald/flow-react-components/Option"; import { sleepLong } from "@/content/03-components/actions/action/examples/lib"; import Section from "@mittwald/flow-react-components/Section"; import { IconBackup, IconSettings, IconSshSftp, } from "@mittwald/flow-react-components/Icons"; import { Select } from "@mittwald/flow-react-components/Select"; import ColumnLayout from "@mittwald/flow-react-components/ColumnLayout"; import { Switch } from "@mittwald/flow-react-components/Switch"; import Link from "@mittwald/flow-react-components/Link"; import { DatePicker } from "@mittwald/flow-react-components/DatePicker"; import FieldDescription from "@mittwald/flow-react-components/FieldDescription"; import RadioGroup, { Radio, RadioButton, } from "@mittwald/flow-react-components/RadioGroup"; export default () => { return ( <Row> <ModalTrigger> <Button>Modal S</Button> <Modal size="s"> <Heading> Möchtest du die Bestellung wirklich abbrechen? </Heading> <Content> <Section> <Text> Deine eingegebenen Daten werden nicht gespeichert. </Text> </Section> </Content> <ActionGroup> <Action closeOverlay="Modal"> <Action action={sleepLong}> <Button color="danger"> Bestellung abbrechen </Button> </Action> <Button variant="soft" color="secondary"> Bestellung fortsetzen </Button> </Action> </ActionGroup> </Modal> </ModalTrigger> <ModalTrigger> <Button>Modal M</Button> <Modal size="m"> <Heading> <IconBackup /> <Text>Backup anlegen</Text> </Heading> <Content> <Section> <Text> Das Backup enthält alle Dateien deines Dateisystems und den Inhalt deiner Datenbanken. Dei Erstellung eines Backups dauert in der Regel einige Minuten. </Text> <ColumnLayout m={[1, 1]}> <TextField> <Label>Beschreibung</Label> </TextField> <Select isRequired> <Label>Speicherdauer</Label> <Option>7 Tage</Option> <Option>14 Tage</Option> <Option>30 Tage</Option> <Option>6 Monate</Option> <Option>12 Monate</Option> </Select> </ColumnLayout> </Section> </Content> <ActionGroup> <Action closeOverlay="Modal"> <Action action={sleepLong}> <Button color="accent"> Backup anlegen </Button> </Action> <Button variant="soft" color="secondary"> Abbrechen </Button> </Action> </ActionGroup> </Modal> </ModalTrigger> <ModalTrigger> <Button>OffCanvas S</Button> <Modal size="s" offCanvas> <Heading> <IconSettings /> Dashboard-Einstellungen </Heading> <Content> <Section> <Heading>Widget-Sichtbarkeit</Heading> <Text> Aktiviere und deaktiviere die Widgets, die du wirklich benötigst. So bestimmst du selbst, wie dein Dashboard aussehen soll. </Text> <div style={{ display: "flex", flexDirection: "column", gap: "32px", }} > <ColumnLayout s={[1]} gap="s"> <Switch>Erste Schritte</Switch> <Text> Im Onboarding erklären wir dir alles Wichtige im mStudio. </Text> <Link>Erste Schritte starten</Link> </ColumnLayout> <ColumnLayout s={[1]} gap="s"> <Switch defaultSelected> mittwald Status </Switch> <Text> Wir informieren dich über Wartung und Störungen. </Text> </ColumnLayout> <ColumnLayout s={[1]} gap="s"> <Switch>mittwald Produkt-Slider</Switch> <Text> Im Produkt-Slider erhälst du Informationen und einen schnellen Einstieg in weitere mittwald Produkte. </Text> </ColumnLayout> <ColumnLayout s={[1]} gap="s"> <Switch defaultSelected> Neue Features </Switch> <Text> Wir entwickeln das mStudio stetig weiter Alle kommenden Features findest du auf der <Link>Roadmap</Link>. </Text> <Link>Changelog öffnen</Link> </ColumnLayout> <ColumnLayout s={[1]} gap="s"> <Switch defaultSelected> Neue Blogbeiträge </Switch> <Text> Wir zeigen dir den neuesten mittwald Blogartikel an. </Text> <Link>Blogartikel öffnen</Link> </ColumnLayout> <ColumnLayout s={[1]} gap="s"> <Switch>Lastschift Hinweis</Switch> <Text> Wir informieren über die neue Möglichkeit, deine Rechnungen per Lastschrift zu bezahlen. </Text> </ColumnLayout> </div> </Section> </Content> <ActionGroup> <Action closeOverlay="Modal"> <Button variant="soft" color="secondary"> Schließen </Button> </Action> </ActionGroup> </Modal> </ModalTrigger> <ModalTrigger> <Button>OffCanvas M</Button> <Modal size="m" offCanvas> <Heading> <IconSshSftp /> SFTP-Benutzer anlegen </Heading> <Content> <Section> <Heading>Beschreibung</Heading> <Text> Mit einem SFTP-Benutzer kannst du dich mit deinem Projekt verbinden, um z.B. Dateien hochzuladen. </Text> <ColumnLayout m={[1, 1]}> <TextField isRequired> <Label>Bezeichnung</Label> </TextField> <DatePicker> <Label>Ablaufdatum</Label> <FieldDescription> Nach diesem Datum wird der SFTP-Benutzer gelöscht. </FieldDescription> </DatePicker> </ColumnLayout> </Section> <Section> <Heading>Authentifizierung</Heading> <Text> Wähle zwischen der Authentifikation per Passwort oder über einen SSH-Key. </Text> <RadioGroup variant="segmented" value="password" > <Radio value="password">Passwort</Radio> <Radio value="ssh">SSH-Key</Radio> </RadioGroup> <ColumnLayout s={[1, 1]}> <TextField isRequired> <Label>Passwort</Label> </TextField> </ColumnLayout> </Section> <Section> <Heading>Berechtigungen</Heading> <Text> Wähle hier die Berechtigungen aus, mit denen der SFTP-Benutzer zugreifen darf. </Text> <RadioGroup s={[1, 1]} defaultValue="read&write" > <RadioButton value="write"> <Text>Lesezugriff</Text> <Content> Der SFTP-Benutzer kann Dateien einsehen und herunterladen. </Content> </RadioButton> <RadioButton value="read&write"> <Text>Lese- und Schreibzugriff</Text> <Content> Der SFTP-Benutzer kann Dateien einsehen, bearbeiten, hoch und herunterladen. </Content> </RadioButton> </RadioGroup> </Section> <Section> <Heading>Verzeichnisauswahl</Heading> <Text> Hier legst du das Verzeichnis fest, auf das der SFTP-Benutzer Zugriff hat. </Text> <TextField isRequired> <Label>Pfad</Label> </TextField> </Section> </Content> <ActionGroup> <Action closeOverlay="Modal"> <Action action={sleepLong}> <Button color="accent"> SFTP-Benutzer anlegen </Button> </Action> <Button variant="soft" color="secondary"> Abbrechen </Button> </Action> </ActionGroup> </Modal> </ModalTrigger> </Row> ); }
Size S: Ein Modal in der Size S (Breite 660 px) wird zum Beispiel für einfache Abfragen, ob etwas gelöscht werden soll, verwendet.
Size M: Ein Modal in der Size M (Breite 900 px) wird für komplexere Dialoge (z.B. Erstellungs-Prozesse mit mehreren Eingabefeldern) verwendet.
Alternativ zum <ModalTrigger />
kann das Modal auch über einen Controller
gesteuert werden.
import Modal from "@mittwald/flow-react-components/Modal"; import Content from "@mittwald/flow-react-components/Content"; import Text from "@mittwald/flow-react-components/Text"; import TextField from "@mittwald/flow-react-components/TextField"; import Label from "@mittwald/flow-react-components/Label"; import ActionGroup from "@mittwald/flow-react-components/ActionGroup"; import Button from "@mittwald/flow-react-components/Button"; import Heading from "@mittwald/flow-react-components/Heading"; import Action from "@mittwald/flow-react-components/Action"; import { sleepLong } from "@/content/03-components/actions/action/examples/lib"; import { useOverlayController } from "@mittwald/flow-react-components/controller"; import Section from "@mittwald/flow-react-components/Section"; export default () => { const controller = useOverlayController("Modal"); return ( <> <Button onPress={controller.open}> Modal öffnen </Button> <Modal controller={controller}> <Heading>Organisation anlegen</Heading> <Content> <Section> <Text> Eine Organisation kannst du dir wie ein Unternehmen vorstellen. An diesem Ort verwaltest du deine Mitarbeiter, Zahlungsmodalitäten und kannst deine Rechnungen einsehen. </Text> <TextField isRequired> <Label>Organisationsname</Label> </TextField> </Section> </Content> <ActionGroup> <Action closeOverlay="Modal"> <Action action={sleepLong}> <Button color="accent"> Organisation anlegen </Button> </Action> <Button variant="soft" color="secondary"> Abbrechen </Button> </Action> </ActionGroup> </Modal> </> ); }
Verwende ein Modal, um...
Modal und OffCanvas erfüllen beide den Zweck, dem Nutzer Informationen in einem Overlay zu vermitteln. Auch technisch sind sie identisch.
Dennoch sollte je nach Anwendungsfall zwischen beiden unterschieden werden, da die unterschiedliche Darstellung verschiedene Vorteile mit sich bringt.
einfache Dialoge wie Abfragen oder kurze Anlege-Prozesse anzuzeigen.
kurze Bearbeitungsmöglichkeiten darzustellen.
Inhalte anzuzeigen, die kein Scrollen erfordern und für die die Breite des Modals ausreicht.
Inhalte anzuzeigen, die nicht gekürzt werden können und ein Scrollen erfordern.
sehr breite Inhalte anzuzeigen.
In den meisten Fällen ist eine ActionGroup im Footer des Modals erforderlich, um Eingaben zu bestätigen oder das Modal zu verlassen.
Beachte bei der Verwendung jedoch, dass manche Inhalte keine Bestätigung erfordern, da ...
In diesen Fällen benötigt die ActionGroup keine Hauptaktion.
Manche Eingaben erfordern keine explizite Bestätigung. An diesen Stellen ist es ausreichend, nur einen “Schließen”-Button in der ActionGroup des Modal Footers anzuzeigen.
Beachte bei der Heading folgende Punkte:
Unter der Heading befindet sich oft ein beschreibender Text. Dabei sind folgende Punkte zu beachten:
Wenn die Bildschirmgröße weniger als 551 px beträgt, dann füllt das Modal die gesamte Breite des Bildschirms aus und wird am unteren Rand des Bildschirms angezeigt.
Das Schließen eines Modals sollte einfach sein, besonders wenn im Modal nichts Wichtiges vom Nutzer bestätigt werden muss. Es sollte möglich sein, es durch einen Klick außerhalb des Modals oder durch Drücken der "Schließen"- oder "Abbrechen"-Taste oder der Esc-Taste zu schließen.