Verwende ein SegmentedControl, um z. B. ...
- eine Einfachauswahl von 2 bis 5 Optionen anzuzeigen. - Optionen anzuzeigen, die aus 1 bis 2 Wörtern bestehen.
- Optionen anzuzeigen, die den darunterliegenden Inhalt verändern.
Verwende <SegmentedControl />
, um ein SegmentedControl anzuzeigen.
import { Label, Segment, SegmentedControl, } from "@mittwald/flow-react-components"; <SegmentedControl defaultValue="ssh-key"> <Label>Authentifizierungsart</Label> <Segment value="ssh-key">SSH-Key</Segment> <Segment value="passwort">Passwort</Segment> </SegmentedControl>
Unterhalb des SegmentedControls kann sich der Inhalt je nach Bedarf ändern.
import { ColumnLayout, FieldDescription, Label, Section, Segment, SegmentedControl, TextField, } from "@mittwald/flow-react-components"; import { useState } from "react"; export default () => { const [showContent, setShowContent] = useState<boolean>(false); return ( <Section> <SegmentedControl defaultValue="lastschrift" onChange={() => setShowContent(!showContent)} > <Label>Zahlungsart</Label> <Segment value="lastschrift">Lastschrift</Segment> <Segment value="Rechnung">Rechnung</Segment> {showContent && ( <FieldDescription> Wähle bitte eine Bankverbindung für die Bezahlung mit SEPA-Lastschrift aus. </FieldDescription> )} </SegmentedControl> {showContent && ( <ColumnLayout> <TextField isRequired> <Label>Kontoinhaber</Label> </TextField> <TextField isRequired> <Label>IBAN</Label> </TextField> </ColumnLayout> )} </Section> ); }
Innerhalb der <SegmentedControl />
kann eine hilfreiche <FieldDescription />
eingebaut werden.
import { FieldDescription, Label, Segment, SegmentedControl, } from "@mittwald/flow-react-components"; <SegmentedControl defaultValue="cloud"> <Label>Speicherplatz</Label> <Segment value="cloud">Cloud</Segment> <Segment value="lokal">Lokal</Segment> <FieldDescription> Speicherplatz kann jederzeit geändert werden </FieldDescription> </SegmentedControl>
Eine SegmentedControl hat 2 States: Default und Disabled. Die Optionen verfügen über die States Default, Hover, Pressed, Disabled, Focused und Selected.
import { Label, Section, Segment, SegmentedControl, } from "@mittwald/flow-react-components"; <Section> <SegmentedControl defaultValue="dev"> <Label>Rolle</Label> <Segment value="entwickler">Entwickler</Segment> <Segment value="designer">Designer</Segment> <Segment value="geschäftsführer"> Geschäftsführer </Segment> <Segment value="andere">Andere</Segment> </SegmentedControl> <SegmentedControl defaultValue="dev" isDisabled> <Label>Rolle</Label> <Segment value="entwickler">Entwickler</Segment> <Segment value="designer">Designer</Segment> <Segment value="geschäftsführer"> Geschäftsführer </Segment> <Segment value="andere">Andere</Segment> </SegmentedControl> </Section>
Selected: Wird eine Option vom User ausgewählt, so erhält er den Zustand Selected. Es kann immer nur eine Option diesen Status haben. Zu Beginn ist immer die erste Option vorausgewählt.
Disabled: Einzelne Optionen oder die gesamte SegmentedControl können den State Disabled haben. Wenn die SegmentedControl den State Disabled erhält, erhalten automatisch auch alle Optionen ebenfalls diesen State, sodass sie vom User nicht ausgewählt werden können.
Das SegmentedControl springt in eine kompakte Variante um, sobald der Container
kleiner als der gesetzte Breakpoint ist. Im Default passiert das bei 550px, was
der containerBreakpointSize=”m”
entspricht. Über diese Property kann die Größe
mit Werten zwischen xs
und xl
überschrieben werden.
import { ColumnLayout, Label, Segment, SegmentedControl, } from "@mittwald/flow-react-components"; <ColumnLayout m={[1, 1]}> <SegmentedControl defaultValue="entwickler" containerBreakpointSize="xl" > <Label>Rolle</Label> <Segment value="entwickler">Entwickler</Segment> <Segment value="geschäftsführer"> Geschäftsführer </Segment> <Segment value="andere">Andere</Segment> </SegmentedControl> <SegmentedControl defaultValue="entwickler" containerBreakpointSize="xs" > <Label>Rolle</Label> <Segment value="entwickler">Entwickler</Segment> <Segment value="geschäftsführer"> Geschäftsführer </Segment> <Segment value="andere">Andere</Segment> </SegmentedControl> </ColumnLayout>
Benutze die ContextualHelp Komponente, wenn du weitere Informationen bereitstellen möchtest, und diese zu lang für die FieldDescription sind.
import { Button, ContextualHelp, ContextualHelpTrigger, Heading, Label, Segment, SegmentedControl, Text, } from "@mittwald/flow-react-components"; <SegmentedControl defaultValue="lastschrift"> <Label> Zahlungsart <ContextualHelpTrigger> <Button /> <ContextualHelp> <Heading>Weitere Informationen</Heading> <Text> Hier gibt es weitere Informationen, die zu lang für die FieldDescription sind. </Text> </ContextualHelp> </ContextualHelpTrigger> </Label> <Segment value="lastschrift">Lastschrift</Segment> <Segment value="Rechnung">Rechnung</Segment> </SegmentedControl>
Property | Type | Default | Description |
---|---|---|---|
className | string | ((values: RadioGroupRenderProps & { defaultClassName: string; }) => string) | - | The CSS className for the element. A function may be provided to compute the class based on component state. |
style | CSSProperties | ((values: RadioGroupRenderProps & { defaultStyle: CSSProperties; }) => CSSProperties) | - | The inline style for the element. A function may be provided to compute the style based on component state. |
validationBehavior | "native" | "aria" | 'native' | Whether to use native HTML form validation to prevent form submission when the value is missing or invalid, or mark the field as required or invalid via ARIA. |
isDisabled | boolean | - | Whether the input is disabled. |
isReadOnly | boolean | - | Whether the input can be selected but not changed by the user. |
isRequired | boolean | - | Whether user input is required on the input before form submission. |
isInvalid | boolean | - | Whether the input value is invalid. |
validate | ((value: string) => true | ValidationError) | - | A function that returns an error message if a given value is invalid.
Validation errors are displayed to the user when the form is submitted
if |
value | string | - | The current value (controlled). |
defaultValue | string | - | The default value (uncontrolled). |
id | string | - | The element's unique identifier. See MDN. |
name | string | - | The name of the input element, used when submitting an HTML form. See MDN. |
slot | string | - | A slot name for the component. Slots allow the component to receive props from a parent component.
An explicit |
orientation | Orientation | 'vertical' | The axis the Radio Button(s) should align with. |
children | ReactNode | - | |
wrapWith | ReactElement<unknown, string | JSXElementConstructor<any>> | - | |
containerBreakpointSize | ContainerBreakpointSize | - | |
ref | Ref<HTMLDivElement> | - | Allows getting a ref to the component instance.
Once the component unmounts, React will set |
key | Key | - |
Achte bei der Verwendung eines SegmentedControl darauf, dass...
Verwende einen SegmentedControl, um...
Flow bietet verschiedene Auswahl-Components an. Das SegmentedControl und die RadioGroup haben viele Gemeinsamkeiten. Die Cards unter dem Text geben hilfreiche Anhaltspunkte zur Unterscheidung.
Das SegmentedControl wird häufig in Formularen oder als Ansichtsfilter verwendet. Bei der Positionierung ist Folgendes zu beachten:
Das SegmentedControl steht über dem angepassten Inhalt.
Ein SegmentedControl darf maximal 5 Optionen enthalten. Bei der Reihenfolge der Optionen ist folgendes zu beachten:
Der selektierte Zustand einer Option ist an der geänderten Farbe und dem Häkchensymbol zu erkennen. Aus diesem Grund sollte das Icon nicht verändert werden. In der aktuellen Version des SegmentedControls sind keine dekorativen oder alleinstehenden Icons vorgesehen.
Das SegmentedControl hat Text in den Optionen und im Label. Dabei ist Folgendes zu beachten:
Das Label und die Antwortmöglichkeiten sind prägnant und verständlich.
Kürzer ist oft besser. Versuche, so wenig Wörter wie möglich im Label und in den Optionen zu verwenden.
Sobald die Breite des Containers kleiner als 551px ist, werden alle Optionen im
SegmentedControl untereinander dargestellt. Dieser Wert kann mit
containerBreakpointSize
angepasst werden. Auch bei schmaleren Containerns
sollte vermieden werden, dass der Text zweizeilig wird oder nicht mehr lesbar
ist.
Falls SegmentedControl ohne Label verwendet wird, muss ein AriaLabel gepflegt werden.