Skip to content

Instantly share code, notes, and snippets.

@m0n4
Last active June 12, 2022 16:50
Show Gist options
  • Save m0n4/e8f291faf53f1f4286a87dac790b4aec to your computer and use it in GitHub Desktop.
Save m0n4/e8f291faf53f1f4286a87dac790b4aec to your computer and use it in GitHub Desktop.
add a chart on pkt.world explorer
// ==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