extends layout block content div.container-fluid(ng-controller='StatsCtrl') div.row(ng-cloak) div.col-xs-12 //- div.col-sm-12 //- h1= title //- p Welcome to #{title} //- div.clearfix div.col-xs-2.stat-holder div.row.big-info.nodesactive(class="{{ nodesActive | nodesActiveClass : nodesTotal }}") div.pull-left.icon-full-width i.icon-node div.pull-left span.small-title active nodes span.big-details {{nodesActive}}/{{nodesTotal}} div.clearfix div.col-xs-2.stat-holder div.row.big-info.uptime(class="{{ upTimeTotal | upTimeClass }}") div.pull-left.icon-full-width i.icon-bulb div.pull-left span.small-title up-time span.big-details {{ upTimeTotal | upTimeFilter }} div.clearfix div.col-xs-2.stat-holder div.row.big-info.difficulty.text-info div.pull-left.icon-full-width i.icon-difficulty div.pull-left span.small-title difficulty span.big-details {{ lastDifficulty }} div.clearfix div.col-xs-2.stat-holder div.row.big-info.bestblock.text-info div.pull-left.icon-full-width i.icon-block div.pull-left span.small-title best block span.big-details {{"#" + bestBlock}} div.clearfix div.col-xs-2.stat-holder div.row.big-info.blocktime(class="{{ lastBlock | timeClass }}") div.pull-left.icon-full-width i.icon-time div.pull-left span.small-title last block span.big-details {{ lastBlock | blockTimeFilter }} div.clearfix div.col-xs-2.stat-holder div.row.big-info.avgblocktime(class="{{ avgBlockTime | timeClass }}") div.pull-left.icon-full-width i.icon-gas div.pull-left span.small-title avg block time span.big-details {{ avgBlockTime | avgTimeFilter }} div.clearfix div.clearfix div.col-xs-12 div.row div.col-xs-8(style="padding-top: 30px;") div.col-xs-3.stat-holder div.row.big-info.chart span.small-title block time span.big-details.spark-blocktimes div.col-xs-3.stat-holder div.row.big-info.chart span.small-title difficulty span.big-details.spark-difficulty div.col-xs-3.stat-holder div.row.big-info.chart span.small-title transactions span.big-details.spark-transactions div.col-xs-3.stat-holder div.row.big-info.chart span.small-title gas spending span.big-details.spark-gasspending //- div.clearfix div.col-xs-4 div.col-xs-12 nodemap#mapHolder(data="map") div.clearfix div.col-xs-12 //- h1 Nodes in detail table.table.table-striped thead tr.text-info th i.icon-node(data-toggle="tooltip", data-placement="top", title="Node") th i.icon-laptop(data-toggle="tooltip", data-placement="top", title="Node type") th.th-latency i.icon-clock(data-toggle="tooltip", data-placement="top", title="Node latency") th i.icon-mining(data-toggle="tooltip", data-placement="top", title="Is mining") th i.icon-group(data-toggle="tooltip", data-placement="top", title="Peers") th i.icon-network(data-toggle="tooltip", data-placement="top", title="Pending transactions") th i.icon-block(data-toggle="tooltip", data-placement="top", title="Last node block") th.hidden-sm.hidden-xs   th i.icon-check-o(data-toggle="tooltip", data-placement="top", title="Block transactions") th i.icon-time(data-toggle="tooltip", data-placement="top", title="Last block time") th i.icon-gas(data-toggle="tooltip", data-placement="top", title="Propagation time") th i.icon-bulb(data-toggle="tooltip", data-placement="top", title="Up-time") tbody tr(ng-repeat='node in nodes', class="{{ node.stats | mainClass : bestBlock }}") td(rel="{{node.id}}") span(data-toggle="tooltip", data-placement="top", data-original-title="{{node.geo | geoTooltip}}") {{node.info.name}} span.small  ({{node.info.ip}}) td div.small(ng-bind-html="node.info.node | nodeVersion") //- div.small {{node.info.os}}, {{node.info.os_v}} td.small(class="{{ node.stats | latencyClass }}") {{node.stats | latencyFilter}} td(class="{{ node.stats.mining | miningClass }}") i.small(class="{{ node.stats.mining | miningIconClass }}") td(class="{{ node.stats.peers | peerClass }}", style="padding-left: 18px;") {{node.stats.peers}} td(style="padding-left: 18px;") {{node.stats.pending}} td(class="{{ node.stats.block.number | blockClass : bestBlock }}") {{'#' + node.stats.block.number}} td(class="{{ node.stats.block.number | blockClass : bestBlock }}").hidden-sm.hidden-xs span.small {{node.stats.block.hash | hashFilter}} //- div.small Difficulty: {{node.stats.block.difficulty | gasFilter}} | Gas used: {{node.stats.block.gasUsed | gasFilter}} | Min gas price: {{node.stats.block.minGasPrice | gasFilter}} | Gas limit: {{node.stats.block.gasLimit | gasFilter}} td(style="padding-left: 18px;") {{node.stats.block.transactions.length || 0}} td(class="{{ node.stats.block.timestamp | timeClass }}") {{node.stats.block.received | blockTimeFilter }} td(class="{{ node.stats.block.received | propagationTimeClass : node.stats.block.firstarrived }}") {{node.stats.block.received | blockPropagationFilter : node.stats.block.firstarrived}} td(class="{{ node.stats.uptime | upTimeClass }}") {{ node.stats.uptime | upTimeFilter }}