1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-16 00:06:40 +01:00
unleash.unleash/public/js/components/log/LogEntry.jsx

88 lines
2.4 KiB
React
Raw Normal View History

2014-11-13 15:14:41 +01:00
var React = require('react');
2015-02-04 18:47:37 +01:00
var moment = require('moment');
2014-11-13 15:14:41 +01:00
var DIFF_PREFIXES = {
A: ' ',
E: ' ',
D: '-',
N: '+'
2015-03-23 18:47:23 +01:00
};
var SPADEN_CLASS = {
A: 'blue', // array edited
E: 'blue', // edited
D: 'negative', // deleted
N: 'positive', // added
2015-03-23 18:47:23 +01:00
};
2014-11-14 07:29:55 +01:00
var LogEntry = React.createClass({
2014-11-13 15:14:41 +01:00
propTypes: {
event: React.PropTypes.object.isRequired
},
render: function() {
2015-02-04 18:47:37 +01:00
var date = moment(this.props.event.createdAt);
2014-11-13 15:14:41 +01:00
return (
<tr>
<td>
2015-02-04 18:47:37 +01:00
{date.format('ll')}<br />
{date.format('HH:mm')}
</td>
<td>
<strong>{this.props.event.data.name}</strong><em>[{this.props.event.type}]</em>
</td>
<td style={{maxWidth: 300}}>
{this.renderEventDiff()}
</td>
<td>{this.props.event.createdBy}</td>
2014-11-13 15:14:41 +01:00
</tr>
);
},
renderFullEventData: function() {
var localEventData = JSON.parse(JSON.stringify(this.props.event.data));
delete localEventData.description;
delete localEventData.name;
var prettyPrinted = JSON.stringify(localEventData, null, 2);
2015-03-23 18:47:23 +01:00
return (<code className='JSON smalltext man'>{prettyPrinted}</code>);
},
renderEventDiff: function() {
if (!this.props.showFullEvents && this.props.event.diffs) {
var changes = this.props.event.diffs.map(this.buildDiff);
2015-03-23 18:47:23 +01:00
return (
<code className='smalltext man'>{changes.length === 0 ? '(no changes)' : changes}</code>
);
} else {
return this.renderFullEventData();
}
},
buildDiff: function(diff, idx) {
var change;
var key = diff.path.join('.');
if (diff.lhs !== undefined && diff.rhs !== undefined) {
change = (
<div>
<div className={SPADEN_CLASS.D}>- {key}: {JSON.stringify(diff.lhs)}</div>
<div className={SPADEN_CLASS.N}>+ {key}: {JSON.stringify(diff.rhs)}</div>
</div>
);
} else {
2015-03-23 18:47:23 +01:00
var spadenClass = SPADEN_CLASS[diff.kind];
var prefix = DIFF_PREFIXES[diff.kind];
2015-03-23 18:47:23 +01:00
change = (<div className={spadenClass}>{prefix} {key}: {JSON.stringify(diff.rhs)}</div>);
}
2015-03-23 18:47:23 +01:00
return (<div key={idx}>{change}</div>);
2014-11-13 15:14:41 +01:00
}
2014-11-13 15:14:41 +01:00
});
2015-03-23 18:47:23 +01:00
module.exports = LogEntry;