Files
weave-scope/client/app/scripts/components/metric-selector-item.js
David Kaltschmidt 96aae9bc99 Migrate from Flux to Redux
* better state visibility
* pure state changes
* state debug panel (show: crtl-h, move: ctrl-w)
2016-04-27 17:21:46 +02:00

65 lines
1.5 KiB
JavaScript

import React from 'react';
import classNames from 'classnames';
import { connect } from 'react-redux';
import { selectMetric, pinMetric, unpinMetric } from '../actions/app-actions';
class MetricSelectorItem extends React.Component {
constructor(props, context) {
super(props, context);
this.onMouseOver = this.onMouseOver.bind(this);
this.onMouseClick = this.onMouseClick.bind(this);
}
onMouseOver() {
const k = this.props.metric.get('id');
this.props.selectMetric(k);
}
onMouseClick() {
const k = this.props.metric.get('id');
const pinnedMetric = this.props.pinnedMetric;
if (k === pinnedMetric) {
this.props.unpinMetric(k);
} else {
this.props.pinMetric(k);
}
}
render() {
const {metric, selectedMetric, pinnedMetric} = this.props;
const id = metric.get('id');
const isPinned = (id === pinnedMetric);
const isSelected = (id === selectedMetric);
const className = classNames('metric-selector-action', {
'metric-selector-action-selected': isSelected
});
return (
<div
key={id}
className={className}
onMouseOver={this.onMouseOver}
onClick={this.onMouseClick}>
{metric.get('label')}
{isPinned && <span className="fa fa-thumb-tack"></span>}
</div>
);
}
}
function mapStateToProps(state) {
return {
selectedMetric: state.get('selectedMetric'),
pinnedMetric: state.get('pinnedMetric')
};
}
export default connect(
mapStateToProps,
{ selectMetric, pinMetric, unpinMetric }
)(MetricSelectorItem);