mirror of
https://github.com/weaveworks/scope.git
synced 2026-03-03 18:20:27 +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
99 lines
3.2 KiB
JavaScript
99 lines
3.2 KiB
JavaScript
import React from 'react';
|
|
import { connect } from 'react-redux';
|
|
import { debounce } from 'lodash';
|
|
|
|
import NodesChart from '../charts/nodes-chart';
|
|
import NodesGrid from '../charts/nodes-grid';
|
|
import NodesResources from '../components/nodes-resources';
|
|
import NodesError from '../charts/nodes-error';
|
|
import DelayedShow from '../utils/delayed-show';
|
|
import { Loading, getNodeType } from './loading';
|
|
import { isTopologyEmpty } from '../utils/topology-utils';
|
|
import { setViewportDimensions } from '../actions/app-actions';
|
|
import {
|
|
isGraphViewModeSelector,
|
|
isTableViewModeSelector,
|
|
isResourceViewModeSelector,
|
|
} from '../selectors/topology';
|
|
|
|
import { VIEWPORT_RESIZE_DEBOUNCE_INTERVAL } from '../constants/timer';
|
|
|
|
|
|
const EmptyTopologyError = show => (
|
|
<NodesError faIconClass="fa-circle-thin" hidden={!show}>
|
|
<div className="heading">Nothing to show. This can have any of these reasons:</div>
|
|
<ul>
|
|
<li>We haven't received any reports from probes recently.
|
|
Are the probes properly configured?</li>
|
|
<li>There are nodes, but they're currently hidden. Check the view options
|
|
in the bottom-left if they allow for showing hidden nodes.</li>
|
|
<li>Containers view only: you're not running Docker,
|
|
or you don't have any containers.</li>
|
|
</ul>
|
|
</NodesError>
|
|
);
|
|
|
|
class Nodes extends React.Component {
|
|
constructor(props, context) {
|
|
super(props, context);
|
|
|
|
this.setDimensions = this.setDimensions.bind(this);
|
|
this.handleResize = debounce(this.setDimensions, VIEWPORT_RESIZE_DEBOUNCE_INTERVAL);
|
|
this.setDimensions();
|
|
}
|
|
|
|
componentDidMount() {
|
|
window.addEventListener('resize', this.handleResize);
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
window.removeEventListener('resize', this.handleResize);
|
|
}
|
|
|
|
render() {
|
|
const { topologyEmpty, topologiesLoaded, nodesLoaded, topologies, currentTopology,
|
|
isGraphViewMode, isTableViewMode, isResourceViewMode } = this.props;
|
|
|
|
// TODO: Rename view mode components.
|
|
return (
|
|
<div className="nodes-wrapper">
|
|
<DelayedShow delay={1000} show={!topologiesLoaded || (topologiesLoaded && !nodesLoaded)}>
|
|
<Loading itemType="topologies" show={!topologiesLoaded} />
|
|
<Loading
|
|
itemType={getNodeType(currentTopology, topologies)}
|
|
show={topologiesLoaded && !nodesLoaded} />
|
|
</DelayedShow>
|
|
{EmptyTopologyError(topologiesLoaded && nodesLoaded && topologyEmpty)}
|
|
|
|
{isGraphViewMode && <NodesChart />}
|
|
{isTableViewMode && <NodesGrid />}
|
|
{isResourceViewMode && <NodesResources />}
|
|
</div>
|
|
);
|
|
}
|
|
|
|
setDimensions() {
|
|
this.props.setViewportDimensions(window.innerWidth, window.innerHeight);
|
|
}
|
|
}
|
|
|
|
|
|
function mapStateToProps(state) {
|
|
return {
|
|
isGraphViewMode: isGraphViewModeSelector(state),
|
|
isTableViewMode: isTableViewModeSelector(state),
|
|
isResourceViewMode: isResourceViewModeSelector(state),
|
|
currentTopology: state.get('currentTopology'),
|
|
nodesLoaded: state.get('nodesLoaded'),
|
|
topologies: state.get('topologies'),
|
|
topologiesLoaded: state.get('topologiesLoaded'),
|
|
topologyEmpty: isTopologyEmpty(state),
|
|
};
|
|
}
|
|
|
|
|
|
export default connect(
|
|
mapStateToProps,
|
|
{ setViewportDimensions }
|
|
)(Nodes);
|