2015-06-05 11:06:36 +02:00
|
|
|
'use strict';
|
|
|
|
|
2015-05-26 16:48:48 +02:00
|
|
|
import React from 'react';
|
|
|
|
import classNames from 'classnames';
|
|
|
|
|
2015-06-04 13:48:07 +02:00
|
|
|
import { ColumnModel } from './models/table_models';
|
2015-05-26 16:48:48 +02:00
|
|
|
|
|
|
|
import TableItem from './table_item';
|
|
|
|
|
2015-05-27 08:24:13 +02:00
|
|
|
// This component is implemented as recommended here: http://stackoverflow.com/a/25723635/1263876
|
2015-05-26 16:48:48 +02:00
|
|
|
let TableItemSelectable = React.createClass({
|
|
|
|
|
|
|
|
propTypes: {
|
2015-06-04 13:48:07 +02:00
|
|
|
columnList: React.PropTypes.arrayOf(React.PropTypes.instanceOf(ColumnModel)),
|
2015-05-27 09:05:39 +02:00
|
|
|
columnContent: React.PropTypes.object,
|
2015-05-27 09:56:26 +02:00
|
|
|
parentId: React.PropTypes.number,
|
2015-06-05 11:06:36 +02:00
|
|
|
className: React.PropTypes.string,
|
|
|
|
selectItem: React.PropTypes.func
|
2015-05-26 16:48:48 +02:00
|
|
|
},
|
|
|
|
|
2015-05-26 19:50:18 +02:00
|
|
|
selectItem() {
|
|
|
|
this.props.selectItem(this.props.parentId, this.props.columnContent.edition_number);
|
|
|
|
},
|
|
|
|
|
2015-05-26 16:48:48 +02:00
|
|
|
render() {
|
|
|
|
let tableItemClasses = classNames({
|
|
|
|
'ascribe-table-item-selected': this.props.columnContent.selected
|
|
|
|
});
|
|
|
|
|
2015-06-01 14:10:11 +02:00
|
|
|
return (
|
2015-06-05 11:06:36 +02:00
|
|
|
<TableItem
|
2015-06-01 14:10:11 +02:00
|
|
|
className={tableItemClasses + ' ' + this.props.className}
|
|
|
|
columnList={this.props.columnList}
|
|
|
|
columnContent={this.props.columnContent}
|
2015-06-05 11:06:36 +02:00
|
|
|
onClick={this.selectItem} />
|
2015-06-01 14:10:11 +02:00
|
|
|
);
|
2015-06-01 11:51:03 +02:00
|
|
|
|
2015-05-26 16:48:48 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
export default TableItemSelectable;
|