Flex
Use Grid to build multiple column layouts. This Grid works on twelve column system, and it contains variants of 12, 6, 4, 3, 2, and 1 column for each breakpoint.
Examples
<Flex direction={{ mobile: "column", tablet: "row" }}>
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</Flex>
Basic Usage
Row layout:
<Flex>
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</Flex>
Column layout:
<Flex direction="column">
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</div>
Usage with a list:
<Flex elementType="ul" direction="column">
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</Flex>
â¹ï¸ For the row layout, the Flex component uses the display: flex
CSS property. For the column
layout, display: grid
is used because of technical advantages: better overflow control or
alignment API consistency.
Responsive Direction
To create a responsive layout, pass an object as the value for the direction
property, using breakpoint keys to specify different layouts for each screen size.
<Flex direction={{ mobile: 'column', tablet: 'row' }}>
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</Flex>
Wrapping
By default, Flex items will not wrap. To enable wrapping on all breakpoints, use the
isWrapping
prop.
<Flex isWrapping>
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</Flex>
Responsive Wrapping
To create a responsive wrapping layout, pass an object as the value for the isWrapping
property, using breakpoint keys to specify different wrapping for each screen size.
<Flex isWrapping={{ mobile: true, tablet: false }}>
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</Flex>
Alignment
Horizontal Alignment
Flex can be horizontally aligned as stretched (default), to the left, center, or right. Additionally, you can evenly distribute the items using the space-between value. These values come from the extended alignmentX dictionary.
Vertical Alignment
Similarly to the horizontal alignment, Flex can be vertically aligned as stretched (default), to the top, center, bottom. There is also an option to align the items to the baseline. These values come from the extended alignmentY dictionary.
Example:
<Flex alignmentX="right" alignmentY="baseline">
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</div>
Responsive Alignment
To create a responsive alignment, pass an object as the value for the property, using breakpoint keys to specify different alignments for each screen size.
Example:
<Flex alignmentX={{ mobile: 'left', tablet: 'space-between' }} alignmentY={{ mobile: 'stretch', tablet: 'baseline' }}>
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</Flex>
Custom Spacing
You can use the spacing
prop to apply custom spacing between items in both horizontal and vertical directions. The prop
accepts either a spacing token (e.g. space-100
) or an object with breakpoint keys and spacing token values.
Custom spacing:
<Flex spacing="space-1200">
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</div>
Custom responsive spacing:
<Flex spacing={{ mobile: 'space-400', tablet: 'space-800' }}>
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</Flex>
API
Name | Type | Default | Required | Description |
---|---|---|---|---|
alignmentX |
[AlignmentXExtended dictionary | object ] |
stretch |
No | Apply horizontal alignment of items, use an object to set responsive values, e.g. { mobile: 'left', tablet: 'center', desktop: 'right' } |
alignmentY |
[AlignmentYExtended dictionary | object ] |
stretch |
No | Apply vertical alignment of items, use an object to set responsive values, e.g. { mobile: 'top', tablet: 'center', desktop: 'bottom' } |
direction |
[[Direction dictionary][direction-dictionary] | object ] |
row |
No | Direction of the items, use an object to set responsive values, e.g. { mobile: 'row', tablet: 'row', desktop: 'column' } |
elementType |
HTML element | div |
No | Element type to use for the Grid |
isWrapping |
[ bool | object ] |
false |
No | Whether items will wrap, use an object to set responsive values, e.g. { mobile: true, tablet: true, desktop: false } |
spacing |
[SpaceToken | Partial<Record<BreakpointToken, SpaceToken>> ] |
â | No | Apply custom spacing in both horizontal and vertical directions between items |
On top of the API options, the components accept additional attributes. If you need more control over the styling of a component, you can use style props and escape hatches.