Package Exports
- react-native-flex-grid
- react-native-flex-grid/lib/commonjs/index.js
- react-native-flex-grid/lib/module/index.js
- react-native-flex-grid/src/index.ts
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (react-native-flex-grid) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
react-native-flex-grid
A react-native flexbox grid similar to bootstap's web grid.

Check the DEMO, built with Storybook and react-native-web.
Getting Started
Installation
NPM:
npm install --save react-native-flex-grid
YARN:
yarn add react-native-flex-grid
Usage
import { Container, Row, Col } from 'react-native-flex-grid';
const MyComponent = (
<Container fluid>
<Row>
<Col>
<Text>.col</Text>
</Col>
</Row>
<Row>
<Col>
<Text>.col</Text>
</Col>
<Col>
<Text>.col</Text>
</Col>
<Col>
<Text>.col</Text>
</Col>
<Col>
<Text>.col</Text>
</Col>
</Row>
<Row>
<Col xs="3">
<Text>.col-3</Text>
</Col>
<Col xs="auto">
<Text>.col-auto - variable width content</Text>
</Col>
<Col xs="3">
<Text>.col-3</Text>
</Col>
</Row>
<Row>
<Col xs="6">
<Text>.col-6</Text>
</Col>
<Col xs="6">
<Text>.col-6</Text>
</Col>
</Row>
<Row>
<Col xs="6" sm="4">
<Text>.col-6 .col-sm-4</Text>
</Col>
<Col xs="6" sm="4">
<Text>.col-6 .col-sm-4</Text>
</Col>
<Col sm="4">
<Text>.col-sm-4</Text>
</Col>
</Row>
<Row>
<Col sm={5} smOrder={2} smOffset={1}>
<Text>.col-sm-5 .order-sm-2 .offset-sm-1</Text>
</Col>
<Col sm={5} smOrder={1} smOffset={1}>
<Text>.col-sm-5 .order-sm-1 .offset-sm-1</Text>
</Col>
</Row>
<Row>
<Col md={6} mdOffset={3} sm={12}>
<Text>.col-sm-12 .col-md-6 .offset-md-3</Text>
</Col>
</Row>
<Row>
<Col sm="auto" smOffset={1}>
<Text>.col-sm-auto .offset-sm-1</Text>
</Col>
<Col sm="auto" smOffset={1}>
<Text>.col-sm-auto .offset-sm-1</Text>
</Col>
</Row>
</Container>
);
export default MyComponent;
Component Props - can be used to customize Layout components
Container
export declare interface ContainerProps
extends React.ComponentProps<typeof View> {
/** Fluid Container */
fluid?: boolean;
/** No Padding */
noPadding?: boolean;
/** Element to render - defaults to View */
Element?: React.ElementType;
}
Row
export declare interface RowProps extends React.ComponentProps<typeof View> {
/** Gutter size -- [Bootstrap Gutters](https://getbootstrap.com/docs/5.0/layout/gutters/) */
gx?: 0 | 1 | 2 | 3 | 4 | 5;
/** Direction */
dir?: 'ltr' | 'rtl';
/** Element to render - defaults to View */
Element?: React.ElementType;
}
Col
export declare interface ColProps extends React.ComponentProps<typeof View> {
/** xs size */
xs?: number | string;
/** sm size */
sm?: number | string;
/** md size */
md?: number | string;
/** lg size */
lg?: number | string;
/** xl size */
xl?: number | string;
/** xs offset */
xsOffset?: number | string;
/** sm offset */
smOffset?: number | string;
/** md offset */
mdOffset?: number | string;
/** lg offset */
lgOffset?: number | string;
/** xl offset */
xlOffset?: number | string;
/** xs order */
xsOrder?: number | string;
/** sm order */
smOrder?: number | string;
/** md order */
mdOrder?: number | string;
/** lg order */
lgOrder?: number | string;
/** xl order */
xlOrder?: number | string;
/** Gutter size -- [Bootstrap Gutters](https://getbootstrap.com/docs/5.0/layout/gutters/) */
gx?: 0 | 1 | 2 | 3 | 4 | 5;
/** Direction */
dir?: 'ltr' | 'rtl';
/** Element to render - defaults to View */
Element?: React.ElementType;
}
Modifying Grid Configuration
The grid is 100% modifiable, checkout the detailed docs
Responsive utils
Checkout the detailed docs for a set of useful responsive utilities like css/scss like media queries.
Development
Checkout the detailed docs to understand how to run the repo locally and how to develop with it.
Helpful resources
- Blogpost
- Bootstrap layout documentation
- Reactstrap layout documentation
- React Native Extended StyleSheet
Contributing
Pull requests are highly appreciated! For major changes, please open an issue first to discuss what you would like to change.