Playground
Verwende <ColumnLayout />
, um ein ColumnLayout darzustellen.
import { ColumnLayout, Label, TextField, } from "@mittwald/flow-react-components"; <ColumnLayout rowGap="s" columnGap="l"> <TextField isRequired> <Label>Vorname</Label> </TextField> <TextField isRequired> <Label>Nachname</Label> </TextField> <TextField isRequired> <Label>Straße</Label> </TextField> <TextField isRequired> <Label>Hausnummer</Label> </TextField> </ColumnLayout>
Das ColumnLayout erzeugt ein flexibles Spalten-Layout, das für die Breakpoints s, m und l individuell angepasst werden kann. Diese Breakpoints beziehen sich nicht auf die Bildschirmgröße, sondern auf die Breite des Containers, in dem das ColumnLayout verwendet wird. Standardmäßig sind die Spalten wie folgt definiert:
- Größe
s
bis 550 Pixel Breite:[1]
- Größe
m
bis 850 Pixel Breite:[1, 1]
- Größe
l
ab 851 Pixel Breite:[1, 1, 1]
In der Definition der Spalten-Breiten werden sowohl die Anzahl der Spalten als auch ihr Größenverhältnis festgelegt. Eine Aufteilung wie [1, 2, 1] erzeugt zum Beispiel drei Spalten, wobei die mittlere Spalte doppelt so breit ist wie die beiden äußeren.
Benutzerdefinierte Werte
Für jeden Breakpoint können eigene Werte für die Spaltenanzahl und deren Größenverhältnis festgelegt werden. Wenn für einen größeren Breakpoint keine eigenen Werte definiert sind, übernimmt er automatisch die Werte des nächstkleineren Breakpoints. Standardwerte werden nur verwendet, wenn bei keinem kleineren Breakpoint benutzerdefinierte Werte angegeben sind. Beispiel:
- Größe
s
bis 550 Pixel Breite:[1]
(Default-Wert) - Größe
m
bis 850 Pixel Breite:[2, 1]
(benutzerdefinierter Wert) - Größe
l
ab 851 Pixel Breite:[2, 1]
(Wert von m geerbt)
In diesem Beispiel wurde für den Breakpoint m
eine benutzerdefinierte
Spaltenaufteilung festgelegt. Der Breakpoint l
übernimmt diese Aufteilung von
m
, anstatt auf den Standardwert von [1, 1, 1]
zurückzufallen. Da für den
Breakpoint s
kein benutzerdefinierter Wert angegeben wurde, bleibt er beim
Standardwert von [1]
.
import { ColumnLayout, Label, TextField, } from "@mittwald/flow-react-components"; <ColumnLayout m={[2, 1]}> <TextField isRequired> <Label>Straße</Label> </TextField> <TextField isRequired> <Label>Hausnummer</Label> </TextField> </ColumnLayout>
Ausgeblendete Spalten
Als Werte für die Breakpoints kann neben Zahlen auch null
mitgegeben werden.
Das führt dazu, dass die entsprechende Spalte ausgeblendet wird. Hier wird
beispielsweise das Bild in der kleinsten Ansicht ausgeblendet:
import { ColumnLayout, Text, Image, Section, Heading, } from "@mittwald/flow-react-components"; <ColumnLayout s={[1, null]} m={[2, 1]} l={[5, 1]}> <Section> <Heading>Lorem ipsum dolor sit amet</Heading> <Text> Lorem ipsum dolor sit amet consectetur adipisicing elit. Cumque eius quam quas vel voluptas, ullam aliquid fugit. Voluptate harum accusantium rerum ullam modi blanditiis vitae, laborum ea tempore, dolore voluptas. Earum pariatur, similique corrupti id officia perferendis. Labore, similique. Earum, quas in. At dolorem corrupti blanditiis nulla deserunt laborum! Corrupti delectus aspernatur nihil nulla obcaecati ipsam porro sequi rem? Quam. </Text> </Section> <Image src="https://mittwald.github.io/flow/assets/mittwald_logo_rgb.jpg" alt="mittwald" /> </ColumnLayout>
Abstände
Die Abstände des ColumnLayout können in drei Stufen angepasst werden:
- s = 8px
- m = 16px
- l = 24px
Die property rowGap
steuert die Abstände zwischen den Zeilen (oben und unten),
columnGap
die Abstände zwischen den Spalten (rechts und links) und gap
setzt
alle Abstände gleichzeitig (oben, unten, rechts und links).
import { ColumnLayout, Label, TextField, } from "@mittwald/flow-react-components"; <ColumnLayout m={[1, 1]} rowGap="s" columnGap="l"> <TextField isRequired> <Label>Vorname</Label> </TextField> <TextField isRequired> <Label>Nachname</Label> </TextField> <ColumnLayout s={[2, 1]} columnGap="m"> <TextField isRequired> <Label>Straße</Label> </TextField> <TextField isRequired> <Label>Hausnummer</Label> </TextField> </ColumnLayout> <TextField isRequired> <Label>Ort</Label> </TextField> </ColumnLayout>