Skip to content

Commit

Permalink
show message if topology is empty
Browse files Browse the repository at this point in the history
  • Loading branch information
davkal committed Sep 21, 2015
1 parent bd58e91 commit 8a1a697
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 6 deletions.
31 changes: 26 additions & 5 deletions client/app/scripts/charts/nodes-chart.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ const Edge = require('./edge');
const Naming = require('../constants/naming');
const NodesLayout = require('./nodes-layout');
const Node = require('./node');
const NodesError = require('./nodes-error');

const MARGINS = {
top: 130,
Expand Down Expand Up @@ -151,6 +152,27 @@ const NodesChart = React.createClass({
}, this);
},

renderMaxNodesError: function() {
return (
<NodesError faIconClass="fa-ban" hidden={!this.state.maxNodesExceeded}>
<div className="centered">Too many nodes to show in the browser.<br />We're working on it, but for now, try a different view?</div>
</NodesError>
);
},

renderEmptyTopologyError: function() {
return (
<NodesError faIconClass="fa-circle-thin" hidden={_.size(this.state.nodes) > 0}>
<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 hidden settings in the bottom-left.</li>
<li>Empty containers view only: you're not running Docker, or you don't have any containers.</li>
</ul>
</NodesError>
);
},

render: function() {
const nodeElements = this.renderGraphNodes(this.state.nodes, this.state.nodeScale);
const edgeElements = this.renderGraphEdges(this.state.edges, this.state.nodeScale);
Expand All @@ -165,15 +187,14 @@ const NodesChart = React.createClass({
translate = shiftTranslate;
wasShifted = true;
}
const errorClassNames = this.state.maxNodesExceeded ? 'nodes-chart-error' : 'nodes-chart-error hide';
const svgClassNames = this.state.maxNodesExceeded || _.size(nodeElements) === 0 ? 'hide' : '';
const errorEmpty = this.renderEmptyTopologyError();
const errorMaxNodesExceeded = this.renderMaxNodesError();

return (
<div className="nodes-chart">
<div className={errorClassNames}>
<span className="nodes-chart-error-icon fa fa-ban" />
<div>Too many nodes to show in the browser.<br />We're working on it, but for now, try a different view?</div>
</div>
{errorEmpty}
{errorMaxNodesExceeded}
<svg width="100%" height="100%" className={svgClassNames} onMouseUp={this.handleMouseUp}>
<Spring endValue={{val: translate, config: [80, 20]}}>
{function(interpolated) {
Expand Down
24 changes: 24 additions & 0 deletions client/app/scripts/charts/nodes-error.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
const React = require('react');

const NodesError = React.createClass({

render: function() {
let classNames = 'nodes-chart-error';
if (this.props.hidden) {
classNames += ' hide';
}
let iconClassName = 'fa ' + this.props.faIconClass;

return (
<div className={classNames}>
<div className="nodes-chart-error-icon">
<span className={iconClassName} />
</div>
{this.props.children}
</div>
);
}

});

module.exports = NodesError;
7 changes: 6 additions & 1 deletion client/app/styles/main.less
Original file line number Diff line number Diff line change
Expand Up @@ -191,10 +191,15 @@ h2 {
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
text-align: center;
color: @text-secondary-color;
width: 33%;

.heading {
font-size: 125%;
}

&-icon {
text-align: center;
opacity: 0.25;
font-size: 320px;
}
Expand Down

0 comments on commit 8a1a697

Please sign in to comment.