// ==UserScript==
// @name TW Achivement Point Ranking
// @namespace n3mesis
// @version 0.1
// @description create a achivement points ranking
// @author n3mesis
// @include http*://*.the-west.*/game.php*
// @grant none
// ==/UserScript==
(function (code) {
var script = document.createElement('script');
script.setAttribute('type', 'application/javascript');
script.textContent = '(' + code + ')();';
document.body.appendChild(script);
document.body.removeChild(script);
})(function () {
N3R = {
window: null,
table: null,
achvptslist: [],
last: null,
allPlayers: null,
rows: {
list: { name: 'Get Playerlist' },
players: { name: 'Load achivement points' },
localStorage: { name: 'Safe ranking in local storage' },
},
};
function progbar(row) {
N3R.rows[row].progbar.getMainDiv().show();
return N3R.rows[row].progbar;
}
async function getallplayers() {
const resp = await fetch(
location.href.split('#')[0] +
'?window=ranking&mode=get_data',
{
credentials: 'include',
headers: {
'User-Agent': navigator.userAgent,
'Accept':
'application/json, text/javascript, */*; q=0.01',
'Content-Type':
'application/x-www-form-urlencoded; charset=UTF-8',
'X-Requested-With': 'XMLHttpRequest',
'Sec-Fetch-Dest': 'empty',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Site': 'same-origin',
},
referrer: location.href.split('#')[0],
body: 'page=0&tab=experience&entries_per_page=50000',
method: 'POST',
mode: 'cors',
}
);
return await resp.json();
}
const getplayerdata = (player_id) =>
new Promise((resolve, reject) => {
Ajax.remoteCallMode(
'profile',
'init',
{ playerId: player_id },
function (player_id) {
if (player_id.error) reject(player_id.error);
else resolve(player_id);
}
);
});
async function importDoIt(m) {
progbar('list').setMaxValue(1);
N3R.allPlayers = await getallplayers();
let max = m
? Math.min(m, N3R.allPlayers.ranking.length)
: N3R.allPlayers.ranking.length;
progbar('list').increase(1);
N3R.achvptslist = [];
progbar('players').setMaxValue(max);
progbar('localStorage').setMaxValue(1);
await getPoints(max);
N3R.achvptslist = N3R.achvptslist.sort(
(a, b) => b.achvpoints - a.achvpoints
);
saveRanking();
N3R.last = timeConv(new Date().valueOf());
progbar('localStorage').increase(1);
}
async function getPoints(max) {
let i = 0;
for (const val of N3R.allPlayers.ranking) {
if (i >= max) return;
let playerdata = await getplayerdata(val.player_id);
N3R.achvptslist.push({
name: val.name,
player_id: val.player_id,
achvpoints: playerdata.achvpoints,
});
progbar('players').increase(1);
i++;
}
}
function applyCss() {
if (!document.getElementById('N3Rstyle')) {
const css =
'.n3_rank{width:15%;margin-left:10px}.n3_name{width:45%}.n3_achivement_points{width:30%}.n3_innerwnd{width:540px;position:absolute;margin-left:5px;top:2px;}.n3_row{width:170px;margin-left:10px}.n3_progress{text-align:center;width:330px;}';
const style = document.createElement('style');
style.innerHTML = css;
style.id = 'N3Rstyle';
document.head.appendChild(style);
}
}
function openImportWindow() {
N3R.window = wman
.open('n3mesis_achvlist', 'Load Achivement Points Ranking', 'noreload nocloseall'
)
.setSize(600, 320)
.setMiniTitle('N3R');
N3R.table = new west.gui.Table(true)
.appendTo(
$('<div class="n3_innerwnd"></div>')
.appendTo(N3R.window.getContentPane())
)
.addColumns(['n3_row', 'n3_progress'])
.appendToCell('head', 'n3_row', 'task')
.appendToCell('head', 'n3_progress', 'progress');
for (var row in N3R.rows) {
N3R.table
.appendRow()
.appendToCell(-1, 'n3_row', N3R.rows[row].name)
.appendToCell(-1, 'n3_progress',
(N3R.rows[row].progbar = new west.gui.Progressbar(0, 0))
.getMainDiv()
.hide()
);
}
}
function openRankingWindow() {
const content = $('<div style="padding:10px;"></div>');
N3R.table = new west.gui.Table();
N3R.table
.addColumn('n3_rank', 'rank')
.addColumn('n3_name', 'name')
.addColumn('n3_achivement_points', 'achivement_points')
.appendToCell('head', 'n3_rank', 'Rank')
.appendToCell('head', 'n3_name', 'Name')
.appendToCell('head', 'n3_achivement_points', 'Achivement points')
.bodyscroll.divMain.style.height = '262px';
for (i = 0; i < N3R.achvptslist.length; i++) {
const val = N3R.achvptslist[i];
const player = '<a href="javascript:PlayerProfileWindow.open(' + val.player_id + ');">' + val.name + '</a>';
const points = '<a href="javascript:AchievementWindow.open(' + val.player_id + ');">' + val.achvpoints + '</a>';
N3R.table
.appendRow()
.appendToCell(-1, 'n3_rank', i + 1)
.appendToCell(-1, 'n3_name', player)
.appendToCell(-1, 'n3_achivement_points', points);
}
const update = new west.gui.Button('Update Ranking');
update.click(async function () {
openImportWindow();
await importDoIt();
openRankingWindow();
});
const partly = new west.gui.Button('Update partly');
partly.setTooltip(
'Update the ranking, but only with the top exp players. So the progress is faster.'
);
partly.click(async function () {
let top = parseInt(
prompt('How many players should be loaded?')
);
if (!top || isNaN(top)) {
return;
}
openImportWindow();
await importDoIt(top);
openRankingWindow();
});
const partlyhtml = $(
'<div style="display: inline-block"></div>'
);
partlyhtml.html(partly.getMainDiv());
const search = new west.gui.Textfield();
search
.addKeyUpListener(function () {
let input = search.getValue();
tableSearch(input);
})
.setPlaceholder('Playername');
content.append(N3R.table.getMainDiv());
content.append(update.getMainDiv());
content.append(partlyhtml);
content.append(search.getMainDiv());
content.append(
'<div style="color:green;margin-top:8px;">Last import: ' + (N3R.last != null ? N3R.last : ' never imported') + '</div>'
);
N3R.window = wman
.open('n3mesis_achvlist', 'Achivement Points Ranking', 'noreload')
.setSize(550, 493)
.setMiniTitle('N3R')
.appendToContentPane(content);
}
function saveRanking() {
localStorage.setItem(
'N3RRanking',
JSON.stringify({
date: new Date().valueOf(),
ranking: N3R.achvptslist,
})
);
}
function loadRanking() {
if (localStorage.getItem('N3RRanking')) {
const storage = JSON.parse(
localStorage.getItem('N3RRanking')
);
N3R.last = timeConv(storage.date);
N3R.achvptslist = storage.ranking;
} else {
return false;
}
}
function timeConv(timestamp) {
let t = new Date(timestamp);
let year = t.getFullYear();
let month = t.getMonth() + 1;
let date = t.getDate();
let hour = t.getHours();
let min = t.getMinutes().toString().padStart(2, '0');
let time = hour + ':' + min + ' ' + date + '.' + month + '.' + year;
return time;
}
function createN3RButton() {
var icon = $('<div></div>')
.attr({
class: 'menulink',
title: 'Achivement Ranking',
})
.css({
'background':
"url('')",
'background-position': '0px 0px',
})
.mouseleave(function () {
$(this).css('background-position', '0px 0px');
})
.mouseenter(function (e) {
$(this).css('background-position', '25px 0px');
})
.click(function () {
start();
});
var bottom = $('<div></div>').attr({
class: 'menucontainer_bottom',
});
$('#ui_menubar .ui_menucontainer:last').after(
$('<div></div>')
.attr({
class: 'ui_menucontainer',
id: 'N3R',
})
.append(icon)
.append(bottom)
);
}
function tableSearch(input) {
for (i = 0; i < N3R.achvptslist.length; i++) {
if (N3R.achvptslist[i].name.toLowerCase().includes(input.toLowerCase())) {
N3R.table.rows[i].show();
} else {
N3R.table.rows[i].hide();
}
}
}
function start() {
applyCss();
loadRanking();
openRankingWindow();
}
createN3RButton();
});