ZeroTierOne/ui/ZeroTierNetwork.jsx

77 lines
2.3 KiB
React
Raw Normal View History

var ZeroTierNetwork = React.createClass({
2015-05-06 19:39:45 -07:00
getInitialState: function() {
2015-05-08 09:39:07 -07:00
return {};
2015-05-06 19:39:45 -07:00
},
leaveNetwork: function(event) {
2015-05-18 16:02:37 -07:00
if (confirm("Are you sure you want to leave this network?")) {
Ajax.call({
url: 'network/'+this.props.nwid+'?auth='+this.props.authToken,
cache: false,
type: 'DELETE',
success: function(data) {
if (this.props.onNetworkDeleted)
this.props.onNetworkDeleted(this.props.nwid);
}.bind(this),
error: function(error) {
}.bind(this)
});
}
event.preventDefault();
},
render: function() {
return (
<div className="zeroTierNetwork">
2015-05-06 19:39:45 -07:00
<div className="networkInfo">
2015-05-08 09:39:07 -07:00
<span className="networkId">{this.props.nwid}</span>&nbsp;
2015-05-06 19:39:45 -07:00
<span className="networkName">{this.props.name}</span>
</div>
<div className="networkProps">
<div className="row">
<div className="name">Status</div>
<div className="value">{this.props['status']}</div>
</div>
<div className="row">
<div className="name">Type</div>
<div className="value">{this.props['type']}</div>
</div>
<div className="row">
<div className="name">MAC</div>
<div className="value zeroTierAddress">{this.props['mac']}</div>
</div>
<div className="row">
<div className="name">MTU</div>
<div className="value">{this.props['mtu']}</div>
</div>
<div className="row">
<div className="name">Broadcast</div>
<div className="value">{(this.props['broadcastEnabled']) ? 'ENABLED' : 'DISABLED'}</div>
</div>
<div className="row">
<div className="name">Bridging</div>
<div className="value">{(this.props['bridge']) ? 'ACTIVE' : 'DISABLED'}</div>
</div>
<div className="row">
<div className="name">Device</div>
<div className="value">{(this.props['portDeviceName']) ? this.props['portDeviceName'] : '(none)'}</div>
</div>
<div className="row">
<div className="name">Managed&nbsp;IPs</div>
<div className="value ipList">
{
this.props['assignedAddresses'].map(function(ipAssignment) {
return (
2015-05-08 10:03:35 -07:00
<div key={ipAssignment} className="ipAddress">{ipAssignment}</div>
);
})
}
</div>
</div>
</div>
2015-05-08 14:47:01 -07:00
<button type="button" className="leaveNetworkButton" onClick={this.leaveNetwork}>Leave&nbsp;Network</button>
</div>
);
}
});