Skip to main content

Grid

A multi-column grid that wraps children into equal-width columns. Built on top of Row, so all Box spacing and alignment props are available.

Usage

import { Card, Grid, Typography } from '@onlynative/components'
import { ThemeProvider } from '@onlynative/core'
import { SafeAreaProvider } from 'react-native-safe-area-context'
import { View } from 'react-native'

export default function App() {
return (
<SafeAreaProvider>
<ThemeProvider>
<View style={{ flex: 1, justifyContent: 'center', padding: 16 }}>
<Grid columns={2} gap="sm">
<Card variant="outlined"><Typography>Item 1</Typography></Card>
<Card variant="outlined"><Typography>Item 2</Typography></Card>
<Card variant="outlined"><Typography>Item 3</Typography></Card>
<Card variant="outlined"><Typography>Item 4</Typography></Card>
</Grid>
</View>
</ThemeProvider>
</SafeAreaProvider>
)
}

How It Works

Each child is wrapped in a cell with flexBasis: ${100 / columns}%, so all columns are equal width. The gap prop controls spacing between cells — cells shrink proportionally to account for it.

Different Column Counts

import { Button, Grid, IconButton, Typography } from '@onlynative/components'
import { ThemeProvider } from '@onlynative/core'
import { SafeAreaProvider } from 'react-native-safe-area-context'
import { View } from 'react-native'

export default function App() {
return (
<SafeAreaProvider>
<ThemeProvider>
<View style={{ flex: 1, justifyContent: 'center', padding: 16, gap: 24 }}>
<Typography variant="titleSmall">Two columns</Typography>
<Grid columns={2} gap="md">
<Button variant="filled" onPress={() => {}}>A</Button>
<Button variant="outlined" onPress={() => {}}>B</Button>
</Grid>
<Typography variant="titleSmall">Four columns</Typography>
<Grid columns={4} gap="sm">
<IconButton icon="heart" accessibilityLabel="Heart" onPress={() => {}} />
<IconButton icon="star" accessibilityLabel="Star" onPress={() => {}} />
<IconButton icon="bell" accessibilityLabel="Bell" onPress={() => {}} />
<IconButton icon="cog" accessibilityLabel="Settings" onPress={() => {}} />
</Grid>
</View>
</ThemeProvider>
</SafeAreaProvider>
)
}

Props

PropTypeDefaultRequiredDescription
columnsnumber-YesNumber of equal-width columns.
wrapbooleanfalseNoWhether children should wrap to the next line when they overflow.
invertedbooleanfalseNoReverses the layout direction (`row-reverse`).
pSpacingValue-NoPadding on all sides
pxSpacingValue-NoHorizontal padding (paddingStart + paddingEnd)
pySpacingValue-NoVertical padding (paddingTop + paddingBottom)
ptSpacingValue-NoPadding top
pbSpacingValue-NoPadding bottom
psSpacingValue-NoPadding start (left in LTR, right in RTL)
peSpacingValue-NoPadding end (right in LTR, left in RTL)
mSpacingValue-NoMargin on all sides
mxSpacingValue-NoHorizontal margin (marginStart + marginEnd)
mySpacingValue-NoVertical margin (marginTop + marginBottom)
mtSpacingValue-NoMargin top
mbSpacingValue-NoMargin bottom
msSpacingValue-NoMargin start
meSpacingValue-NoMargin end
gapSpacingValue-NoGap between children
rowGapSpacingValue-NoRow gap between children
columnGapSpacingValue-NoColumn gap between children
flexnumber-NoFlex value
alignenum-NoAlign items along the cross axis
justifyenum-NoJustify content along the main axis
bgstring-NoBackground color