You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
187 lines
7.7 KiB
187 lines
7.7 KiB
div.table-responsive
|
|
table.table.table-striped.mb-0
|
|
thead
|
|
tr
|
|
//th
|
|
th
|
|
th.data-header.text-right Height
|
|
|
|
if (!hideTimestampColumn)
|
|
th.data-header.text-right
|
|
span.border-dotted(title="UTC timestamp of the block.", data-toggle="tooltip") Date
|
|
|
|
th.data-header.text-right Age
|
|
th.data-header.text-right
|
|
span.border-dotted(title="Time To Mine - The time it took to mine this block after the previous block. 'Fast' blocks (mined in < 5min) are shown in green; 'slow' blocks (mined in > 15min) are shown in red.", data-toggle="tooltip") T.T.M.
|
|
th.data-header.text-right Miner
|
|
th.data-header.text-right
|
|
span.border-dotted(title="The number of transactions included in each block.", data-toggle="tooltip") N(tx)
|
|
|
|
if (blockstatsByHeight)
|
|
th.data-header.text-right
|
|
span.border-dotted(title="The total output of all transactions in each block.", data-toggle="tooltip") Volume
|
|
|
|
th.data-header.text-right
|
|
span.border-dotted(title="The average fee (sat/vB) for all block transactions.", data-toggle="tooltip") Avg Fee
|
|
th.data-header.text-right Σ Fees
|
|
|
|
//th.data-header.text-right Size (kB)
|
|
|
|
if (blocks && blocks.length > 0 && blocks[0].weight)
|
|
th.data-header.text-right % Full
|
|
//span.border-dotted(title="Block weight, in kWu.", data-toggle="tooltip") Weight
|
|
|
|
else
|
|
th.data-header.text-right Size
|
|
small (kB)
|
|
tbody
|
|
|
|
each block, blockIndex in blocks
|
|
if (block && ((sort == "desc" && blockIndex < blocks.length - 1) || (sort == "asc" && (block.height == 0 || blockIndex > 0))))
|
|
tr
|
|
td
|
|
if (sort == "desc")
|
|
small.text-muted #{(blockIndex + offset + 1).toLocaleString()}
|
|
else
|
|
small.text-muted #{(blockIndex + offset).toLocaleString()}
|
|
|
|
td.data-cell.text-monospace.text-right
|
|
if (global.specialBlocks && global.specialBlocks[block.hash])
|
|
a(data-toggle="tooltip", title=(coinConfig.name + " Fun! See block for details"))
|
|
i.fas.fa-certificate.text-primary.mr-1
|
|
|
|
a(href=("/block-height/" + block.height)) #{block.height.toLocaleString()}
|
|
|
|
|
|
- var timeAgoTime = moment.utc(new Date()).diff(moment.utc(new Date(parseInt(block.time) * 1000)));
|
|
- var timeAgo = moment.duration(timeAgoTime);
|
|
|
|
- var timeDiff = null;
|
|
|
|
if (sort == "asc")
|
|
if (blockIndex > 0)
|
|
- var timeDiff = moment.duration(moment.utc(new Date(parseInt(block.time) * 1000)).diff(moment.utc(new Date(parseInt(blocks[blockIndex - 1].time) * 1000))));
|
|
else
|
|
if (blockIndex < blocks.length - 1)
|
|
- var timeDiff = moment.duration(moment.utc(new Date(parseInt(block.time) * 1000)).diff(moment.utc(new Date(parseInt(blocks[blockIndex + 1].time) * 1000))));
|
|
|
|
if (!hideTimestampColumn)
|
|
td.data-cell.text-monospace.text-right
|
|
- var timestampHuman = block.time;
|
|
include timestamp-human.pug
|
|
|
|
|
|
td.data-cell.text-monospace.text-right
|
|
if (sort != "asc" && blockIndex == 0 && offset == 0 && timeAgoTime > (15 * 60 * 1000))
|
|
- var timeAgoTime = block.time;
|
|
span.text-danger.border-dotted(title="It's been > 15 min since this latest block.", data-toggle="tooltip")
|
|
include ./time-ago-text.pug
|
|
else
|
|
- var timeAgoTime = block.time;
|
|
include ./time-ago-text.pug
|
|
|
|
td.data-cell.text-monospace.text-right
|
|
if (timeDiff)
|
|
- var colorClass = "text-muted";
|
|
if (timeDiff < 300000)
|
|
- var colorClass = "text-success";
|
|
if (timeDiff > 900000)
|
|
- var colorClass = "text-danger";
|
|
|
|
span.font-weight-light(class=colorClass)
|
|
span #{timeDiff.format()}
|
|
|
|
if (false)
|
|
if (timeDiff.asMinutes() < 1)
|
|
span #{parseInt(timeDiff.asSeconds())}s
|
|
else
|
|
span #{parseInt(timeDiff.asMinutes())}m #{parseInt(timeDiff.asSeconds())}s
|
|
|
|
else
|
|
if (block.height == 0)
|
|
small.border-dotted.text-muted(title="Not applicable: genesis block has no previous block to compare to.", data-toggle="tooltip") N/A (genesis)
|
|
else
|
|
span.font-weight-light.text-muted -
|
|
|
|
td.data-cell.text-monospace.text-right
|
|
if (block.miner && block.miner.name)
|
|
small.rounded.bg-primary.text-white.px-2.py-1(data-toggle="tooltip", title=("Identified by: " + block.miner.identifiedBy)) #{utils.ellipsize(block.miner.name, 10)}
|
|
else
|
|
span ?
|
|
|
|
|
|
td.data-cell.text-monospace.text-right #{block.tx.length.toLocaleString()}
|
|
|
|
if (blockstatsByHeight)
|
|
td.data-cell.text-monospace.text-right
|
|
if (blockstatsByHeight[block.height])
|
|
- var currencyValue = parseInt(new Decimal(blockstatsByHeight[block.height].total_out).plus(blockstatsByHeight[block.height].subsidy).plus(blockstatsByHeight[block.height].totalfee).dividedBy(coinConfig.baseCurrencyUnit.multiplier));
|
|
- var currencyValueDecimals = 0;
|
|
include ./value-display.pug
|
|
|
|
else
|
|
span 0
|
|
|
|
td.data-cell.text-monospace.text-right
|
|
- var currencyValue = new Decimal(block.totalFees).dividedBy(block.strippedsize).times(coinConfig.baseCurrencyUnit.multiplier).toDecimalPlaces(1);
|
|
span #{currencyValue}
|
|
|
|
// idea: show typical tx fee, maybe also optimized fee if not segwit
|
|
if (false)
|
|
- var feeEstimateVal = currencyValue.times(166).dividedBy(coinConfig.baseCurrencyUnit.multiplier);
|
|
span.border-dotted(title=`Value: ${feeEstimateVal}`, data-toggle="tooltip") #{currencyValue}
|
|
|
|
td.data-cell.text-monospace.text-right
|
|
- var currencyValue = new Decimal(block.totalFees);
|
|
- var currencyValueDecimals = 3;
|
|
include ./value-display.pug
|
|
|
|
|
|
|
|
if (false)
|
|
td.data-cell.text-monospace.text-right
|
|
- var bSizeK = parseInt(block.size / 1000);
|
|
span #{bSizeK.toLocaleString()}
|
|
|
|
if (blocks && blocks.length > 0 && blocks[0].weight)
|
|
td.data-cell.text-monospace.text-right
|
|
if (true)
|
|
- var full = new Decimal(block.weight).dividedBy(coinConfig.maxBlockWeight).times(100);
|
|
- var full2 = full.toDP(2);
|
|
|
|
span #{full2}
|
|
if (full > 90)
|
|
img(src="/img/block-fullness-3.png", style="width: 18px; height: 18px;")
|
|
else if (full > 50)
|
|
img(src="/img/block-fullness-2.png", style="width: 18px; height: 18px;")
|
|
else if (full > 25)
|
|
img(src="/img/block-fullness-1.png", style="width: 18px; height: 18px;")
|
|
else
|
|
img(src="/img/block-fullness-0.png", style="width: 18px; height: 18px;")
|
|
|
|
else
|
|
- var bWeightK = parseInt(block.weight / 1000);
|
|
- var fullPercent = new Decimal(100 * block.weight / coinConfig.maxBlockWeight).toDecimalPlaces(1);
|
|
|
|
span #{bWeightK.toLocaleString()}
|
|
small.font-weight-light.text-muted (#{fullPercent}%)
|
|
|
|
- var bSizeK = parseInt(block.size / 1000);
|
|
span.ml-1(data-toggle="tooltip", title=`Size: ${bSizeK.toLocaleString()} kB`)
|
|
i.fas.fa-ellipsis-h.text-muted
|
|
|
|
div.progress(style="height: 4px;")
|
|
div.progress-bar(role="progressbar", style=("width: " + fullPercent + "%;"), aria-valuenow=parseInt(100 * block.weight / coinConfig.maxBlockWeight), aria-valuemin="0" ,aria-valuemax="100")
|
|
|
|
else
|
|
td.data-cell.text-monospace.text-right
|
|
- var bSizeK = parseInt(block.size / 1000);
|
|
- var fullPercent = new Decimal(100 * block.size / coinConfig.maxBlockSize).toDecimalPlaces(1);
|
|
|
|
span #{bSizeK.toLocaleString()}
|
|
small.font-weight-light.text-muted (#{fullPercent}%)
|
|
|
|
div.progress(style="height: 4px;")
|
|
div.progress-bar(role="progressbar", style=("width: " + fullPercent + "%;"), aria-valuenow=parseInt(100 * block.size / coinConfig.maxBlockSize), aria-valuemin="0" ,aria-valuemax="100")
|
|
|
|
- var lastBlock = block;
|