ethstats-server/src/poa/views/index.jade

170 lines
9.8 KiB
Plaintext
Raw Normal View History

2015-05-27 08:12:35 +02:00
//- index.jade
extends ./layout.jade
2014-12-03 04:08:49 +01:00
block content
2015-01-20 19:29:31 +01:00
div.container-fluid(ng-controller='StatsCtrl')
2015-03-06 22:22:03 +01:00
div.row(ng-cloak)
2015-04-24 07:48:49 +02:00
div.col-xs-2.stat-holder
div.big-info.bestblock.text-info
div.pull-left.icon-full-width
i.icon-block
2015-04-29 07:49:43 +02:00
div.big-details-holder
2015-04-24 07:48:49 +02:00
span.small-title best block
span.big-details {{'#'}}{{ bestBlock | number}}
div.clearfix
2015-04-06 01:28:42 +02:00
div.col-xs-2.stat-holder
2015-04-09 00:48:27 +02:00
div.big-info.blocktime(class="{{ lastBlock | timeClass : true }}")
2015-04-06 01:28:42 +02:00
div.pull-left.icon-full-width
i.icon-time
2015-04-29 07:49:43 +02:00
div.big-details-holder
2015-04-06 01:28:42 +02:00
span.small-title last block
2015-05-19 21:07:06 +02:00
span.big-details {{ lastBlock | blockTimeFilter }}
//- span.big-details(time-ago="lastBlock")
2015-04-06 01:28:42 +02:00
div.clearfix
div.col-xs-2.stat-holder
2015-04-06 12:47:11 +02:00
div.big-info.avgblocktime(class="{{ avgBlockTime | avgTimeClass }}")
2015-04-06 01:28:42 +02:00
div.pull-left.icon-full-width
i.icon-gas
2015-04-29 07:49:43 +02:00
div.big-details-holder
2015-04-06 01:28:42 +02:00
span.small-title avg block time
span.big-details {{ avgBlockTime | avgTimeFilter }}
div.clearfix
2015-04-28 13:04:39 +02:00
div.col-xs-2.stat-holder
2018-12-01 01:00:07 +01:00
div.big-info.gasprice.text-info
2015-04-28 13:04:39 +02:00
div.pull-left.icon-full-width
2018-12-01 01:00:07 +01:00
i.icon-gasprice
2015-04-29 07:49:43 +02:00
div.big-details-holder
2018-12-01 01:00:07 +01:00
span.small-title gas price
span.big-details {{ bestStats.gasPrice.toString() | gasPriceFilter }}
2015-04-28 13:04:39 +02:00
div.clearfix
2015-04-28 14:22:01 +02:00
div.col-xs-2.stat-holder
2018-12-01 01:14:59 +01:00
div.big-info.gasprice.text-highlight
2015-04-28 14:22:01 +02:00
div.pull-left.icon-full-width
i.icon-difficulty
2015-04-29 07:49:43 +02:00
div.big-details-holder
2018-12-01 01:00:07 +01:00
span.small-title gas limit
span.big-details {{ bestStats.block.gasLimit }} gas
div.clearfix
div.col-xs-2.stat-holder
div.big-info.active-nodes(class="{{ nodesActive | nodesActiveClass : nodesTotal }}")
div.pull-left.icon-full-width
i.icon-node
div.big-details-holder
span.small-title active nodes
span.big-details {{nodesActive}}/{{nodesTotal}}
2015-04-28 14:22:01 +02:00
div.clearfix
2015-04-06 01:28:42 +02:00
div.clearfix
2015-01-20 19:29:31 +01:00
2015-04-17 12:19:53 +02:00
div.row(ng-cloak)
2018-12-01 01:00:07 +01:00
div.col-xs-2.stat-holder
div.big-info.chart(class="{{ avgBlockTime | avgTimeClass }}")
i.icon-time
span.small-title block time
sparkchart.big-details.spark-blocktimes(data="{{lastBlocksTime.join(',')}}", tooltipsuffix="s")
div.clearfix
div.col-xs-2.stat-holder.xpull-right
div.big-info.chart.xdouble-chart(class="{{ blockPropagationAvg | propagationAvgTimeClass : true }}")
i.icon-gas
span.small-title block propagation
histogram.big-details.d3-blockpropagation(data="blockPropagationChart")
div.clearfix
div.col-xs-2.stat-holder
div.big-info.chart.text-info
i.icon-uncle
span.small-title transactions
sparkchart.big-details.spark-transactions(data="{{transactionDensity.join(',')}}")
div.clearfix
div.col-xs-2.stat-holder
div.big-info.chart.text-info
i.icon-gasprice
span.small-title gas spending
sparkchart.big-details.spark-gasspending(data="{{gasSpending.join(',')}}")
div.clearfix
div.col-xs-2.stat-holder
div.big-info.chart.text-info
i.icon-difficulty
span.small-title gas limit
sparkchart.big-details.spark-difficulty(data="{{lastGasLimit.join(',')}}")
div.clearfix
div.col-xs-2.stat-holder.xpull-right
div.big-info.chart.xdouble-chart.text-danger
2018-12-01 01:14:59 +01:00
//- i.icon-hashrate
2018-12-01 01:00:07 +01:00
span.small-title last blocks miners
div.blocks-holder(ng-repeat='miner in miners track by miner.miner', data-toggle="tooltip", data-placement="right", data-original-title="{{miner.blocks}}")
div.block-count(class="{{miner.blocks | minerBlocksClass : 'text-'}}") {{miner.blocks}}
div.small-title-miner {{miner.miner | minerNameFilter : miner.name}}
minerblock(blocks="{{miner.blocks}}")
div.clearfix
div.clearfix
2015-01-20 19:29:31 +01:00
2015-04-24 11:03:43 +02:00
div.row(ng-cloak, style="padding-top: 10px")
2015-04-24 10:57:37 +02:00
table.table.table-striped
thead
tr.text-info
2015-05-19 01:41:14 +02:00
th.th-nodecheck
i.icon-check-o(data-toggle="tooltip", data-placement="top", title="Pin nodes to display first", ng-click="orderTable(['-stats.block.number', 'stats.block.propagation'], false)")
2015-04-24 10:57:37 +02:00
th.th-nodename
2015-05-19 01:41:14 +02:00
i.icon-node(data-toggle="tooltip", data-placement="top", title="Node name", ng-click="orderTable(['info.name'], false)")
2015-04-24 10:57:37 +02:00
th.th-nodetype
2015-05-19 01:41:14 +02:00
i.icon-laptop(data-toggle="tooltip", data-placement="top", title="Node type", ng-click="orderTable(['info.node'], false)")
2015-04-24 10:57:37 +02:00
th.th-latency
2015-05-19 01:41:14 +02:00
i.icon-clock(data-toggle="tooltip", data-placement="top", title="Node latency", ng-click="orderTable(['stats.latency'], false)")
2015-04-24 10:57:37 +02:00
th
2015-05-27 03:06:39 +02:00
i.icon-mining(data-toggle="tooltip", data-placement="top", title="Is mining", ng-click="orderTable(['-stats.hashrate'], false)")
2015-04-24 10:57:37 +02:00
th
2015-05-19 01:41:14 +02:00
i.icon-group(data-toggle="tooltip", data-placement="top", title="Peers", ng-click="orderTable(['-stats.peers'], false)")
2015-04-24 10:57:37 +02:00
th
2015-05-19 01:41:14 +02:00
i.icon-network(data-toggle="tooltip", data-placement="top", title="Pending transactions", ng-click="orderTable(['-stats.pending'], false)")
2015-04-24 10:57:37 +02:00
th
2015-05-19 01:41:14 +02:00
i.icon-block(data-toggle="tooltip", data-placement="top", title="Last block", ng-click="orderTable(['-stats.block.number', 'stats.block.propagation'], false)")
th.th-blockhash  
2015-05-19 01:51:07 +02:00
th.th-blockhash
i.icon-difficulty(data-toggle="tooltip", data-placement="top", title="Total difficulty", ng-click="orderTable(['-stats.block.totalDifficulty'], false)")
2015-04-24 10:57:37 +02:00
th
2015-05-19 01:41:14 +02:00
i.icon-check-o(data-toggle="tooltip", data-placement="top", title="Block transactions", ng-click="orderTable(['-stats.block.transactions.length'], false)")
2015-04-24 10:57:37 +02:00
th
2015-05-19 01:41:14 +02:00
i.icon-uncle(data-toggle="tooltip", data-placement="top", title="Uncles", ng-click="orderTable(['-stats.block.uncles.length'], false)")
2015-04-24 10:57:37 +02:00
th.th-blocktime
2015-05-19 01:41:14 +02:00
i.icon-time(data-toggle="tooltip", data-placement="top", title="Last block time", ng-click="orderTable(['-stats.block.received'], false)")
2015-04-24 10:57:37 +02:00
th.th-peerPropagationTime
2015-05-19 01:41:14 +02:00
i.icon-gas(data-toggle="tooltip", data-placement="top", title="Propagation time", ng-click="orderTable(['-stats.block.number', 'stats.block.propagation'], false)")
2015-04-24 10:57:37 +02:00
th.th-peerPropagationChart
2015-04-28 17:22:11 +02:00
th.th-peerPropagationAvg
2015-05-19 01:41:14 +02:00
i.icon-gas(data-toggle="tooltip", data-placement="top", title="Average propagation time", ng-click="orderTable(['stats.propagationAvg'], false)")
2015-04-24 10:57:37 +02:00
th
2015-05-19 01:41:14 +02:00
i.icon-bulb(data-toggle="tooltip", data-placement="top", title="Up-time", ng-click="orderTable(['-stats.uptime'], false)")
2015-04-24 10:57:37 +02:00
tbody(ng-cloak)
2015-06-09 11:39:13 +02:00
tr(ng-repeat='node in nodes | orderBy:predicate track by node.id', class="{{ node.stats | mainClass : bestBlock }}", id="node_{{node.id}}")
td.td-nodecheck
i(ng-click="pinNode(node.id)", class="{{ node.pinned | nodePinClass }}", data-toggle="tooltip", data-placement="right", data-original-title="Click to {{ node.pinned ? 'un' : '' }}pin")
2015-04-24 10:57:37 +02:00
td.nodeInfo(rel="{{node.id}}")
span.small(data-toggle="tooltip", data-placement="top", data-html="true", data-original-title="{{node | geoTooltip}}") {{node.info.name}}
2015-08-12 22:55:20 +02:00
//- span.small  ({{node.info.ip}})
2015-04-28 03:42:34 +02:00
a.small(href="https://github.com/ethereum/wiki/wiki/Network-Status#updating", target="_blank", data-toggle="tooltip", data-placement="top", data-html="true", data-original-title="Netstats client needs update.<br>Click this icon for instructions.", class="{{ node.info | nodeClientClass : currentApiVersion }}")
2015-04-28 03:25:49 +02:00
i.icon-warning-o
2015-04-24 10:57:37 +02:00
td
div.small(ng-bind-html="node.info.node | nodeVersion")
2015-06-09 11:39:13 +02:00
td(class="{{ node.readable.latencyClass }}")
span.small {{ node.readable.latency }}
2015-05-04 16:27:37 +02:00
td(class="{{ node.stats.mining | hashrateClass : node.stats.active }}", ng-bind-html="node.stats.hashrate | hashrateFilter : node.stats.mining")
2015-04-24 10:57:37 +02:00
td(class="{{ node.stats.peers | peerClass : node.stats.active }}", style="padding-left: 11px;") {{node.stats.peers}}
td(style="padding-left: 15px;") {{node.stats.pending}}
2015-06-09 18:28:29 +02:00
td(class="{{ node.stats | blockClass : bestBlock }}")
span(class="{{ node.readable.forkMessage ? node.readable.forkClass : '' }}") {{'#'}}{{ node.stats.block.number | number }}
2015-07-30 19:39:19 +02:00
//- a.small(data-toggle="tooltip", data-placement="top", data-html="true", data-original-title="{{ node.readable.forkMessage }}", class="{{ node.readable.forkClass }}")
2015-06-09 18:28:29 +02:00
i.icon-warning-o
2015-04-24 10:57:37 +02:00
td(class="{{ node.stats | blockClass : bestBlock }}")
span.small {{node.stats.block.hash | hashFilter}}
2015-05-19 01:51:07 +02:00
td(class="{{ node.stats | blockClass : bestBlock }}")
span.small {{node.stats.block.totalDifficulty | number}}
2015-04-24 10:57:37 +02:00
td(style="padding-left: 14px;") {{node.stats.block.transactions.length || 0}}
td(style="padding-left: 14px;") {{node.stats.block.uncles.length || 0}}
2015-05-19 21:07:06 +02:00
td(class="{{ node.stats.block.received | timeClass : node.stats.active }}") {{node.stats.block.received | blockTimeFilter }}
2015-04-24 10:57:37 +02:00
td(class="{{ node.stats | propagationTimeClass : bestBlock }}")
div.propagationBox
span {{node.stats.block.propagation | blockPropagationFilter}}
td.peerPropagationChart(class="{{node.id}}")
2015-05-19 18:26:30 +02:00
nodepropagchart(data="{{node.history.join(',')}}")
td(class="{{ node.stats | propagationNodeAvgTimeClass : bestBlock }}") {{ node.stats | blockPropagationAvgFilter : bestBlock }}
2015-04-24 10:57:37 +02:00
td(class="{{ node.stats.uptime | upTimeClass : node.stats.active }}") {{ node.stats.uptime | upTimeFilter }}