|
|
|
extends layout
|
|
|
|
|
|
|
|
block content
|
|
|
|
div.container-fluid(ng-controller='StatsCtrl')
|
|
|
|
div.page-latency(ng-cloak)
|
|
|
|
span.small-title page latency:#[ ]
|
|
|
|
span(class="{{ {active: true, latency: latency} | latencyClass }}") {{latency}} ms
|
|
|
|
div.row(ng-cloak)
|
|
|
|
div.col-xs-2.stat-holder
|
|
|
|
div.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.big-info.uptime(class="{{ upTimeTotal | upTimeClass : true }}")
|
|
|
|
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.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 | number }}
|
|
|
|
div.clearfix
|
|
|
|
div.col-xs-2.stat-holder
|
|
|
|
div.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 | number}}
|
|
|
|
div.clearfix
|
|
|
|
div.col-xs-2.stat-holder
|
|
|
|
div.big-info.blocktime(class="{{ lastBlock | timeClass : true }}")
|
|
|
|
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.big-info.avgblocktime(class="{{ avgBlockTime | avgTimeClass }}")
|
|
|
|
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.row(ng-cloak)
|
|
|
|
div.col-xs-6.stats-boxes(style="padding-top: 30px;")
|
|
|
|
div.row
|
|
|
|
div.col-xs-4.stat-holder
|
|
|
|
div.big-info.chart
|
|
|
|
span.small-title block time
|
|
|
|
span.big-details.spark-blocktimes
|
|
|
|
|
|
|
|
div.col-xs-4.stat-holder
|
|
|
|
div.big-info.chart
|
|
|
|
span.small-title difficulty
|
|
|
|
span.big-details.spark-difficulty
|
|
|
|
|
|
|
|
div.col-xs-4.stat-holder.pull-right
|
|
|
|
div.big-info.chart.xdouble-chart
|
|
|
|
span.small-title block propagation
|
|
|
|
histogram.big-details.d3-blockpropagation(data="blockPropagationChart")
|
|
|
|
|
|
|
|
div.col-xs-4.stat-holder
|
|
|
|
div.big-info.chart
|
|
|
|
span.small-title uncle count
|
|
|
|
span.big-details.spark-uncles
|
|
|
|
|
|
|
|
div.col-xs-4.stat-holder
|
|
|
|
div.big-info.chart
|
|
|
|
span.small-title transactions
|
|
|
|
span.big-details.spark-transactions
|
|
|
|
|
|
|
|
div.col-xs-4.stat-holder
|
|
|
|
div.big-info.chart
|
|
|
|
span.small-title gas spending
|
|
|
|
span.big-details.spark-gasspending
|
|
|
|
|
|
|
|
div.col-xs-2.stats-boxes(style="padding-top: 30px;")
|
|
|
|
div.row
|
|
|
|
div.col-xs-12.stat-holder
|
|
|
|
div.big-info.chart.double-chart
|
|
|
|
span.small-title last blocks miners
|
|
|
|
div.blocks-holder(ng-repeat='miner in miners', data-toggle="tooltip", data-placement="right", title="{{miner.blocks}}")
|
|
|
|
div.block-count(class="{{miner.blocks | minerBlocksClass : 'text-'}}") {{miner.blocks}}
|
|
|
|
div.small-title-miner {{miner.miner | minerNameFilter : miner.name}}
|
|
|
|
div.block(ng-repeat="i in getNumber(miner.blocks) track by $index", class="{{miner.blocks | minerBlocksClass}}")
|
|
|
|
div.clearfix
|
|
|
|
|
|
|
|
div.col-xs-4
|
|
|
|
div.col-xs-12
|
|
|
|
nodemap#mapHolder(data="map")
|
|
|
|
|
|
|
|
div.clearfix
|
|
|
|
|
|
|
|
div.row(ng-cloak)
|
|
|
|
div.col-xs-12
|
|
|
|
div.row
|
|
|
|
table.table.table-striped
|
|
|
|
thead
|
|
|
|
tr.text-info
|
|
|
|
th.th-nodename
|
|
|
|
i.icon-node(data-toggle="tooltip", data-placement="top", title="Node name", ng-click="orderTable(['-stats.active', 'info.name'], false)")
|
|
|
|
th.th-nodetype
|
|
|
|
i.icon-laptop(data-toggle="tooltip", data-placement="top", title="Node type", ng-click="orderTable(['-stats.active', 'info.node'], false)")
|
|
|
|
th.th-latency
|
|
|
|
i.icon-clock(data-toggle="tooltip", data-placement="top", title="Node latency", ng-click="orderTable(['-stats.active', 'stats.latency'], false)")
|
|
|
|
th
|
|
|
|
i.icon-mining(data-toggle="tooltip", data-placement="top", title="Is mining", ng-click="orderTable(['-stats.active', '-stats.mining'], false)")
|
|
|
|
th
|
|
|
|
i.icon-mining(data-toggle="tooltip", data-placement="top", title="Hashrate", ng-click="orderTable(['-stats.active', '-stats.mining', '-stats.hashrate'], false)")
|
|
|
|
th
|
|
|
|
i.icon-group(data-toggle="tooltip", data-placement="top", title="Peers", ng-click="orderTable(['-stats.active', '-stats.peers'], false)")
|
|
|
|
th
|
|
|
|
i.icon-network(data-toggle="tooltip", data-placement="top", title="Pending transactions", ng-click="orderTable(['-stats.active', '-stats.pending'], false)")
|
|
|
|
th
|
|
|
|
i.icon-block(data-toggle="tooltip", data-placement="top", title="Last block", ng-click="orderTable(['-stats.active', '-stats.block.number', 'stats.block.propagation'], false)")
|
|
|
|
th.th-blockhash #[ ]
|
|
|
|
th
|
|
|
|
i.icon-check-o(data-toggle="tooltip", data-placement="top", title="Block transactions", ng-click="orderTable(['-stats.active', '-stats.block.transactions.length'], false)")
|
|
|
|
th.th-blocktime
|
|
|
|
i.icon-time(data-toggle="tooltip", data-placement="top", title="Last block time", ng-click="orderTable(['-stats.active', '-stats.block.received'], false)")
|
|
|
|
th.th-peerPropagationTime
|
|
|
|
i.icon-gas(data-toggle="tooltip", data-placement="top", title="Propagation time", ng-click="orderTable(['-stats.active', '-stats.block.number', 'stats.block.propagation'], false)")
|
|
|
|
th.th-peerPropagationChart
|
|
|
|
th
|
|
|
|
i.icon-bulb(data-toggle="tooltip", data-placement="top", title="Up-time", ng-click="orderTable(['-stats.active', '-stats.uptime'], false)")
|
|
|
|
tbody(ng-cloak)
|
|
|
|
tr(ng-repeat='node in nodes | orderBy:predicate:reverse', class="{{ node.stats | mainClass : bestBlock }}")
|
|
|
|
td.nodeInfo(rel="{{node.id}}")
|
|
|
|
span.small(data-toggle="tooltip", data-placement="top", data-html="true", data-original-title="{{node | geoTooltip}}") {{node.info.name}}
|
|
|
|
span.small #[ ]({{node.info.ip}})
|
|
|
|
td
|
|
|
|
div.small(ng-bind-html="node.info.node | nodeVersion")
|
|
|
|
td(class="{{ node.stats | latencyClass }}")
|
|
|
|
span.small {{node.stats | latencyFilter}}
|
|
|
|
td(class="{{ node.stats.mining | miningClass : node.stats.active }}")
|
|
|
|
i(class="{{ node.stats.mining | miningIconClass }}")
|
|
|
|
td(class="{{ node.stats.mining | hashpowerClass }}")
|
|
|
|
span.small {{node.stats.hashrate | hashrateFilter}} kH/s
|
|
|
|
td(class="{{ node.stats.peers | peerClass : node.stats.active }}", style="padding-left: 11px;") {{node.stats.peers}}
|
|
|
|
td(style="padding-left: 15px;") {{node.stats.pending}}
|
|
|
|
td(class="{{ node.stats | blockClass : bestBlock }}") {{'#'}}{{ node.stats.block.number | number }}
|
|
|
|
td(class="{{ node.stats | blockClass : bestBlock }}")
|
|
|
|
span.small {{node.stats.block.hash | hashFilter}}
|
|
|
|
td(style="padding-left: 14px;") {{node.stats.block.transactions.length || 0}}
|
|
|
|
td(class="{{ node.stats.block.arrived | timeClass : node.stats.active }}") {{node.stats.block.arrived | blockTimeFilter }}
|
|
|
|
td(class="{{ node.stats | propagationTimeClass : bestBlock }}")
|
|
|
|
div.propagationBox
|
|
|
|
span {{node.stats.block.propagation | blockPropagationFilter}}
|
|
|
|
td.peerPropagationChart(class="{{node.id}}")
|
|
|
|
td(class="{{ node.stats.uptime | upTimeClass : node.stats.active }}") {{ node.stats.uptime | upTimeFilter }}
|