Last active
June 12, 2022 16:50
-
-
Save m0n4/e8f291faf53f1f4286a87dac790b4aec to your computer and use it in GitHub Desktop.
add a chart on pkt.world explorer
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// ==UserScript== | |
// @name pktworld chart | |
// @namespace https://github.com/m0n4 | |
// @version 1.3 | |
// @description add a chart on pkt.world's explorer | |
// @author m0n4 | |
// @match http://pkt.world/explorer?wallet=* | |
// @match https://www.pkt.world/explorer?wallet=* | |
// @require https://cdn.jsdelivr.net/npm/[email protected] | |
// @downloadURL https://gist.github.com/m0n4/e8f291faf53f1f4286a87dac790b4aec/raw/c4f05a10412ba214610e23057f1798db8acda0c8/pktworld_chart.user.js | |
// @updateURL https://gist.github.com/m0n4/e8f291faf53f1f4286a87dac790b4aec/raw/c4f05a10412ba214610e23057f1798db8acda0c8/pktworld_chart.user.js | |
// @icon  | |
// @grant none | |
// ==/UserScript== | |
(function() { | |
'use strict'; | |
var head = document.querySelector('.table.table-hover:not(#blocks) thead tr'); | |
var newTh = document.createElement("th"); | |
newTh.innerText = "Average"; | |
head.appendChild(newTh); | |
var body = document.querySelectorAll('.table.table-hover:not(#blocks) *:not(thead) tr'); | |
for (var tr of body) { | |
try { | |
tr.querySelectorAll('td')[0].childNodes[0].style.color = "black" | |
} catch {} | |
var newTd = document.createElement("td"); | |
var b = tr.querySelectorAll('td')[1].innerText; | |
var p = parseFloat(tr.querySelectorAll('td')[5].innerText.replace(" PKT", "").replace(",", "")); | |
if (p != 0) { newTd.innerHTML = (p/b).toFixed(2)+' PKT'} | |
tr.appendChild(newTd); | |
} | |
var chart = document.createElement('div'); | |
var canvas = document.createElement('canvas'); | |
canvas.setAttribute("id", "graphique"); | |
canvas.setAttribute("height", "90"); | |
chart.appendChild(canvas); | |
var form = document.querySelector('table'); | |
form.after(chart); | |
var meta = document.createElement('meta'); | |
meta.httpEquiv = "refresh"; | |
meta.content = "60"; | |
document.getElementsByTagName('head')[0].appendChild(meta); | |
const colorStock = ['rgb(201, 38, 255)', 'rgb(139, 50, 168)', 'rgb(179, 119, 0)', 'rgb(255, 204, 255)', 'rgb(66, 135, 245)', 'rgb(246, 255, 117)']; | |
var poolList = document.querySelectorAll(".table.table-hover:not(#blocks) tbody tr td:first-child"); | |
poolList = [].slice.call(poolList); | |
poolList = poolList.map(function(e) { return e.innerText; }); | |
const regExp = /\(([^)]+)\)/; | |
var poolColor = new Map(); | |
poolColor.set('Pkteer', "rgb(54, 162, 235)"); | |
poolColor.set('Pkt.world', "rgb(179, 204, 87)"); | |
poolColor.set('Pktpool.io', "rgb(255, 99, 132)"); | |
poolColor.set('Zetahash', "rgb(255, 191, 0)"); | |
for (p of poolList) { | |
if (p.includes("Unknown")) { p = regExp.exec(p)[1]; } | |
if (!(poolColor.has(p))) { poolColor.set(p, colorStock.pop()); } | |
} | |
var summary = document.querySelectorAll('.table.table-hover:not(#blocks) tbody tr'); | |
var name; | |
for (tr of summary) { | |
name = tr.querySelector('td:first-child').innerText; | |
if (name.includes("Unknown")) { name = regExp.exec(name)[1]; } | |
tr.style.background = poolColor.get(name); | |
} | |
var blocks = document.querySelectorAll("#blocks tbody tr"); | |
blocks = [].slice.call(blocks).reverse(); | |
var winner = blocks.map(function(e) { | |
e.childNodes[9].style.color = poolColor.get(e.childNodes[9].innerText); | |
return e.childNodes[9].innerText; | |
}); | |
var pkt = blocks.map(function(e) { | |
return parseFloat(e.childNodes[11].innerText.replace(" PKT", "")); | |
}); | |
var blockNumber = blocks.map(function(e) { | |
return parseInt(e.childNodes[1].innerText); | |
}); | |
var tmp = 0; | |
var mean = []; | |
const len = pkt.length; | |
for(let i = 0 ; i < len; i++) { | |
tmp += pkt[i]; | |
mean.push(tmp/(i+1)); | |
} | |
document.title = '[Avg '+ mean[len-1].toFixed(2) +'] ' + document.title; | |
var ctx = document.getElementById('graphique').getContext('2d'); | |
var myChart = new Chart(ctx, { | |
type: 'bar', | |
data: { | |
datasets: [{ | |
type: 'bar', | |
data: pkt, | |
backgroundColor: [] | |
}, { | |
type: 'line', | |
borderColor: 'rgb(0, 0, 0)', | |
fill: false, | |
pointRadius: 0, | |
borderWidth: 0.7, | |
data: mean | |
}], | |
labels: blockNumber | |
}, | |
options: { | |
legend: { | |
display: false | |
}, | |
scales: { | |
xAxes: [{ | |
gridLines: { | |
display: false | |
}, | |
categoryPercentage: 1.0, | |
barPercentage: 1.0 | |
}], | |
yAxes: [{ | |
ticks: { | |
beginAtZero: true | |
} | |
}] | |
} | |
} | |
}); | |
var dataset = myChart.data.datasets[0]; | |
for (var i = 0; i < len; i++) { | |
dataset.backgroundColor[i] = poolColor.get(winner[i]); | |
} | |
myChart.update(); | |
})(); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment