mirror of
https://github.com/weaveworks/scope.git
synced 2026-03-03 02:00:43 +00:00
* Added resource view selector button * Showing resource boxes in the resource view * Crude CPU resource view prototype * Improved the viewMode state logic * Extracted zooming into a separate wrapper component * Split the layout selectors between graph-view and resource-view * Proper zooming logic for the resource view * Moved all node networks utils to selectors * Improved the zoom caching logic * Further refactoring of selectors * Added sticky labels to the resource boxes * Added panning translation limits in the resource view * Renamed GridModeSelector -> ViewModeSelector * Polished the topology resource view selection logic * Search bar hidden in the resource view * Added per-layer topology names to the resource view * Made metric selectors work for the resource view * Adjusted the viewport selectors * Renamed viewport selector to canvas (+ maximal zoom fix) * Showing more useful metric info in the resource box labels * Fetching only necessary nodes for the resource view * Refactored the resource view layer component * Addressed first batch UI comments (from the Scope meeting) * Switch to deep zooming transform in the resource view to avoid SVG precision errors * Renamed and moved resource view components * Polished all the resource view components * Changing the available metrics selection * Improved and polished the state transition logic for the resource view * Separated zoom limits from the zoom active state * Renaming and bunch of comments * Addressed all the UI comments (@davkal + @fons) * Made graph view selectors independent from resource view selectors
54 lines
1.6 KiB
JavaScript
54 lines
1.6 KiB
JavaScript
import React from 'react';
|
|
import { connect } from 'react-redux';
|
|
import { Map as makeMap } from 'immutable';
|
|
|
|
import NodeResourcesMetricBox from './node-resources-metric-box';
|
|
import NodeResourcesLayerTopology from './node-resources-layer-topology';
|
|
import {
|
|
layerVerticalPositionByTopologyIdSelector,
|
|
layoutNodesByTopologyIdSelector,
|
|
} from '../../selectors/resource-view/layout';
|
|
|
|
|
|
class NodesResourcesLayer extends React.Component {
|
|
render() {
|
|
const { layerVerticalPosition, topologyId, transform, layoutNodes } = this.props;
|
|
|
|
return (
|
|
<g className="node-resources-layer">
|
|
<g className="node-resources-metric-boxes">
|
|
{layoutNodes.toIndexedSeq().map(node => (
|
|
<NodeResourcesMetricBox
|
|
key={node.get('id')}
|
|
color={node.get('color')}
|
|
label={node.get('label')}
|
|
metricSummary={node.get('metricSummary')}
|
|
width={node.get('width')}
|
|
height={node.get('height')}
|
|
x={node.get('offset')}
|
|
y={layerVerticalPosition}
|
|
transform={transform}
|
|
/>
|
|
))}
|
|
</g>
|
|
{!layoutNodes.isEmpty() && <NodeResourcesLayerTopology
|
|
verticalPosition={layerVerticalPosition}
|
|
transform={transform}
|
|
topologyId={topologyId}
|
|
/>}
|
|
</g>
|
|
);
|
|
}
|
|
}
|
|
|
|
function mapStateToProps(state, props) {
|
|
return {
|
|
layerVerticalPosition: layerVerticalPositionByTopologyIdSelector(state).get(props.topologyId),
|
|
layoutNodes: layoutNodesByTopologyIdSelector(state).get(props.topologyId, makeMap()),
|
|
};
|
|
}
|
|
|
|
export default connect(
|
|
mapStateToProps
|
|
)(NodesResourcesLayer);
|