2014-11-13 15:14:41 +01:00
|
|
|
var React = require('react'),
|
2014-11-14 07:29:55 +01:00
|
|
|
LogEntry = require('./LogEntry');
|
2014-11-13 15:14:41 +01:00
|
|
|
|
2014-11-14 07:29:55 +01:00
|
|
|
var LogEntryList = React.createClass({
|
2014-11-13 15:14:41 +01:00
|
|
|
propTypes: {
|
|
|
|
events: React.PropTypes.array.isRequired
|
|
|
|
},
|
|
|
|
|
2015-01-26 16:54:50 +01:00
|
|
|
getInitialState: function() {
|
|
|
|
return {
|
|
|
|
showFullEvents: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2014-11-13 15:14:41 +01:00
|
|
|
render: function() {
|
2014-11-14 07:29:55 +01:00
|
|
|
var logEntryNodes = this.props.events.map(function(event) {
|
2015-01-26 16:54:50 +01:00
|
|
|
return <LogEntry event={event} key={event.id} showFullEvents={this.state.showFullEvents} />;
|
|
|
|
}.bind(this));
|
|
|
|
|
2014-11-13 15:14:41 +01:00
|
|
|
return (
|
2015-01-26 16:54:50 +01:00
|
|
|
<div>
|
|
|
|
<label className="prs fright-ht768 smalltext">
|
|
|
|
Show full events
|
|
|
|
<input type="checkbox" className="mlm" value={this.state.fullEvents} onChange={this.toggleFullEvents}></input>
|
|
|
|
</label>
|
|
|
|
|
2014-11-29 13:55:38 +01:00
|
|
|
<table className='outerborder zebra-striped'>
|
2014-11-13 15:14:41 +01:00
|
|
|
<thead>
|
|
|
|
<tr>
|
2014-11-17 10:10:47 +01:00
|
|
|
<th>When</th>
|
2014-11-13 15:14:41 +01:00
|
|
|
<th>Action</th>
|
2015-01-26 16:54:50 +01:00
|
|
|
<th>
|
|
|
|
Data
|
|
|
|
</th>
|
2014-11-13 15:14:41 +01:00
|
|
|
<th>Author</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
2014-11-14 07:29:55 +01:00
|
|
|
{logEntryNodes}
|
2014-11-13 15:14:41 +01:00
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</div>
|
|
|
|
);
|
2015-01-26 16:54:50 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
toggleFullEvents: function(e) {
|
|
|
|
this.setState({showFullEvents: !this.state.showFullEvents});
|
2014-11-13 15:14:41 +01:00
|
|
|
}
|
2015-01-26 16:54:50 +01:00
|
|
|
|
2014-11-13 15:14:41 +01:00
|
|
|
});
|
|
|
|
|
2014-11-14 07:29:55 +01:00
|
|
|
module.exports = LogEntryList;
|