Build table for react native. Forked from the original 'react-native-table-component' to fix support for newer versions of react-native-web. Not actively maintained/supported.
npm install react-native-table-component-2

All credit for original work goes to Gil2015/react-native-table-component
All credit for converting to TypeScript goes to @m4ttheweric for issuing this PR
This is a table component for react native.
:exclamation: This package is NOT being actively maintained/supported. This is a forked version of react-native-table-component and includes a change to support newer versions of react-native-web.
- Installation
- Changelogs
- Examples
- Properties
- Notice
- License
> yarn add react-native-table-component-2
USE:
``jsx`
import { Table, TableWrapper, Row, Rows, Col, Cols, Cell } from 'react-native-table-component-2';

#### Example1

`jsx
import React, { Component } from 'react';
import { StyleSheet, View } from 'react-native';
import { Table, Row, Rows } from 'react-native-table-component-2';
export default class ExampleOne extends Component {
constructor(props) {
super(props);
this.state = {
tableHead: ['Head', 'Head2', 'Head3', 'Head4'],
tableData: [
['1', '2', '3', '4'],
['a', 'b', 'c', 'd'],
['1', '2', '3', '456\n789'],
['a', 'b', 'c', 'd']
]
};
}
render() {
const state = this.state;
return (
);
}
}
const styles = StyleSheet.create({
container: { flex: 1, padding: 16, paddingTop: 30, backgroundColor: '#fff' },
head: { height: 40, backgroundColor: '#f1f8ff' },
text: { margin: 6 }
});
`
---
#### Example2

`jsx
import React, { Component } from 'react';
import { StyleSheet, View } from 'react-native';
import { Table, TableWrapper, Row, Rows, Col } from 'react-native-table-component-2';
export default class ExampleTwo extends Component {
constructor(props) {
super(props);
this.state = {
tableHead: ['', 'Head1', 'Head2', 'Head3'],
tableTitle: ['Title', 'Title2', 'Title3', 'Title4'],
tableData: [
['1', '2', '3'],
['a', 'b', 'c'],
['1', '2', '3'],
['a', 'b', 'c']
]
};
}
render() {
const state = this.state;
return (
);
}
}
const styles = StyleSheet.create({
container: { flex: 1, padding: 16, paddingTop: 30, backgroundColor: '#fff' },
head: { height: 40, backgroundColor: '#f1f8ff' },
wrapper: { flexDirection: 'row' },
title: { flex: 1, backgroundColor: '#f6f8fa' },
row: { height: 28 },
text: { textAlign: 'center' }
});
`
---
#### Example3

`jsx
import React, { Component } from 'react';
import { StyleSheet, View, ScrollView } from 'react-native';
import { Table, TableWrapper, Row } from 'react-native-table-component-2';
export default class ExampleThree extends Component {
constructor(props) {
super(props);
this.state = {
tableHead: ['Head', 'Head2', 'Head3', 'Head4', 'Head5', 'Head6', 'Head7', 'Head8', 'Head9'],
widthArr: [40, 60, 80, 100, 120, 140, 160, 180, 200]
};
}
render() {
const state = this.state;
const tableData = [];
for (let i = 0; i < 30; i += 1) {
const rowData = [];
for (let j = 0; j < 9; j += 1) {
rowData.push(${i}${j});
}
tableData.push(rowData);
}
return (
{tableData.map((rowData, index) => (
data={rowData}
widthArr={state.widthArr}
style={[styles.row, index % 2 && { backgroundColor: '#F7F6E7' }]}
textStyle={styles.text}
/>
))}
);
}
}
const styles = StyleSheet.create({
container: { flex: 1, padding: 16, paddingTop: 30, backgroundColor: '#fff' },
header: { height: 50, backgroundColor: '#537791' },
text: { textAlign: 'center', fontWeight: '100' },
dataWrapper: { marginTop: -1 },
row: { height: 40, backgroundColor: '#E7E6E1' }
});
`
---
#### Example4

`jsx
import React, { Component } from 'react';
import { StyleSheet, View, Text, TouchableOpacity, Alert } from 'react-native';
import { Table, TableWrapper, Row, Cell } from 'react-native-table-component-2';
export default class ExampleFour extends Component {
constructor(props) {
super(props);
this.state = {
tableHead: ['Head', 'Head2', 'Head3', 'Head4'],
tableData: [
['1', '2', '3', '4'],
['a', 'b', 'c', 'd'],
['1', '2', '3', '4'],
['a', 'b', 'c', 'd']
]
};
}
_alertIndex(index) {
Alert.alert(This is row ${index + 1});
}
render() {
const state = this.state;
const element = (data, index) => (
);
return (
{state.tableData.map((rowData, index) => (
{rowData.map((cellData, cellIndex) => (
data={cellIndex === 3 ? element(cellData, index) : cellData}
textStyle={styles.text}
/>
))}
))}
);
}
}
const styles = StyleSheet.create({
container: { flex: 1, padding: 16, paddingTop: 30, backgroundColor: '#fff' },
head: { height: 40, backgroundColor: '#808B97' },
text: { margin: 6 },
row: { flexDirection: 'row', backgroundColor: '#FFF1C1' },
btn: { width: 58, height: 18, backgroundColor: '#78B7BB', borderRadius: 2 },
btnText: { textAlign: 'center', color: '#fff' }
});
`
---
#### Example5

`jsx
import React, { Component } from 'react';
import { StyleSheet, View, Text, TouchableOpacity, Alert } from 'react-native';
import { Table, TableWrapper, Col, Cols, Cell } from 'react-native-table-component-2';
export default class ExampleFive extends Component {
constructor(props) {
super(props);
const elementButton = value => (
);
this.state = {
tableTitle: ['Title', 'Title2', 'Title3', 'Title4'],
tableData: [
[elementButton('1'), 'a', 'b', 'c', 'd'],
[elementButton('2'), '1', '2', '3', '4'],
[elementButton('3'), 'a', 'b', 'c', 'd']
]
};
}
_alertIndex(value) {
Alert.alert(This is column ${value});
}
render() { {/ Right Wrapper /}
const state = this.state;
return (
{/ Left Wrapper /}
style={styles.title}
heightArr={[30, 30, 30, 30]}
textStyle={styles.titleText}
>
);
}
}
const styles = StyleSheet.create({
container: { flex: 1, padding: 16, paddingTop: 30, backgroundColor: '#fff' },
singleHead: { width: 80, height: 40, backgroundColor: '#c8e1ff' },
head: { flex: 1, backgroundColor: '#c8e1ff' },
title: { flex: 2, backgroundColor: '#f6f8fa' },
titleText: { marginRight: 6, textAlign: 'right' },
text: { textAlign: 'center' },
btn: { width: 58, height: 18, marginLeft: 15, backgroundColor: '#c8e1ff', borderRadius: 2 },
btnText: { textAlign: 'center' }
});
`
---
| Prop | Type | Description | Default |
| ------------------ | ------ | ---------------------------------- | --------------------------------------- |
| data | Array | Table data. | null |null
| style | Style | Container style. | |{ borderWidth: 0, borderColor: #000 }
| borderStyle | Object | Table border line width and color. | |null
| textStyle | Style | Cell font style. | |[]
| flexArr | Array | Flex value per column. | |[]
| widthArr | Array | Width per column. | |[]
| heightArr | Array | Height per line. | |
| ...props | any | more props | |
---
- Cells in Col and Cols components do not support adaptive height.
- Please set the magin value in the textStyle property to adjust the padding and do not use the padding.
- If parent element is not Table component,please add the type of borderstyle.
`jsx``
{/ If parent element is not Table component,please add the type of borderstyle. /}