1
0
mirror of https://github.com/ascribe/onion.git synced 2024-11-15 09:35:10 +01:00
onion/js/components/ascribe_table/table.js

35 lines
1.1 KiB
JavaScript
Raw Normal View History

import React from 'react';
import TableItem from './table_item';
2015-05-20 14:48:57 +02:00
import TableHeader from './table_header';
import TableColumnModel from '../../models/table_column_model';
2015-05-20 16:44:45 +02:00
let Table = React.createClass({
2015-05-20 14:48:57 +02:00
propTypes: {
columnList: React.PropTypes.arrayOf(React.PropTypes.instanceOf(TableColumnModel))
2015-05-20 14:48:57 +02:00
},
render() {
2015-05-20 14:48:57 +02:00
if(this.props.itemList && this.props.itemList.length > 0) {
return (
2015-05-20 17:32:06 +02:00
<div className="ascribe-table">
<TableHeader columnList={this.props.columnList} itemList={this.props.itemList} fetchList={this.props.fetchList} orderAsc={this.props.orderAsc} orderBy={this.props.orderBy} />
2015-05-20 14:48:57 +02:00
{this.props.itemList.map((item, i) => {
return (
<TableItem columnList={this.props.columnList} columnContent={item} key={i} />
2015-05-20 14:48:57 +02:00
);
})}
</div>
);
} else {
return (
<p>Loading</p>
);
}
}
});
2015-05-20 12:00:16 +02:00
export default Table;