mirror of
https://github.com/yldio/copilot.git
synced 2025-01-18 15:00:12 +02:00
48 lines
1.0 KiB
JavaScript
48 lines
1.0 KiB
JavaScript
|
const React = require('React');
|
||
|
const Styled = require('styled-components');
|
||
|
const GraphNodeButton = require('./graph-node-button');
|
||
|
|
||
|
const {
|
||
|
default: styled
|
||
|
} = Styled;
|
||
|
|
||
|
const StyledText = styled.text`
|
||
|
fill: white;
|
||
|
font-family: LibreFranklin;
|
||
|
font-size: 12px;
|
||
|
`;
|
||
|
|
||
|
class GraphNodeMetrics extends React.Component {
|
||
|
|
||
|
render() {
|
||
|
const {
|
||
|
metrics,
|
||
|
metricsPosition
|
||
|
} = this.props;
|
||
|
|
||
|
const metricSpacing = 18;
|
||
|
const metricsText = metrics.map((metric, index) => (
|
||
|
<StyledText x={0} y={12 + metricSpacing*index}>{`${metric.name}: ${metric.stat}`}</StyledText>
|
||
|
));
|
||
|
|
||
|
return (
|
||
|
<g transform={`translate(${metricsPosition.x}, ${metricsPosition.y})`}>
|
||
|
{metricsText}
|
||
|
</g>
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
GraphNodeMetrics.propTypes = {
|
||
|
metrics: React.PropTypes.arrayOf(React.PropTypes.shape({
|
||
|
name: React.PropTypes.string,
|
||
|
stat: React.PropTypes.string
|
||
|
})),
|
||
|
metricsPosition: React.PropTypes.shape({
|
||
|
x: React.PropTypes.number,
|
||
|
y: React.PropTypes.number
|
||
|
})
|
||
|
};
|
||
|
|
||
|
module.exports = GraphNodeMetrics;
|