1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-23 08:16:18 +01:00
onion/js/components/ascribe_table/table_item_selectable.js
2015-07-08 17:35:30 +02:00

42 lines
1.2 KiB
JavaScript

'use strict';
import React from 'react';
import classNames from 'classnames';
import { ColumnModel } from './models/table_models';
import TableItem from './table_item';
// This component is implemented as recommended here: http://stackoverflow.com/a/25723635/1263876
let TableItemSelectable = React.createClass({
propTypes: {
columnList: React.PropTypes.arrayOf(React.PropTypes.instanceOf(ColumnModel)),
columnContent: React.PropTypes.object,
parentId: React.PropTypes.number,
className: React.PropTypes.string,
selectItem: React.PropTypes.func
},
selectItem() {
this.props.selectItem(this.props.parentId, this.props.columnContent.id);
},
render() {
let tableItemClasses = classNames({
'ascribe-table-item-selected': this.props.columnContent.selected
});
return (
<TableItem
className={tableItemClasses + ' ' + this.props.className}
columnList={this.props.columnList}
columnContent={this.props.columnContent}
onClick={this.selectItem} />
);
}
});
export default TableItemSelectable;