// ==UserScript== // @name TW Ranking+ // @namespace Johnny // @version 1.3 // @description Extended Ranking for The West Classic // @author Johnny // @match http://classic.the-west.net/game.php* // @match https://classic.the-west.net/game.php* // @connect 107.170.27.137 // @run-at document-idle // @grant GM_addStyle // @grant GM_xmlhttpRequest // @grant unsafeWindow // @downloadURL none // ==/UserScript== (function() { var towns = []; var lastModified = 0; var windowName = 'RankingPlus'; var style = '\ #menu_ranking_plus a { background: url(""); } \ #window_' + windowName + '_content { overflow-y: scroll; } \ #window_' + windowName + '_content #ranking_table th { cursor: pointer; font-size: 9px; } \ #window_' + windowName + '_content #ranking_table td { padding: 0; text-align: center; vertical-align: middle; } \ #window_' + windowName + '_content #ranking_table .green { font-weight: bold; background: green !important; color: white; } \ #window_' + windowName + '_content #ranking_table .red { font-weight: bold; background: darkred !important; color: white; } \ '; GM_addStyle(style); GM_xmlhttpRequest({ method: 'GET', url: 'http://107.170.27.137/data.json?' + new Date().getTime(), onload: function(resp) { towns = JSON.parse(resp.responseText); var start = resp.responseHeaders.indexOf('Last-Modified:') + 14; lastModified = resp.responseHeaders.substring(start, resp.responseHeaders.indexOf('\n', start)) || 0; } }); var button = document.createElement('li'); button.id = 'menu_ranking_plus'; var buttonLink = document.createElement('a'); buttonLink.onclick = openWindow; buttonLink.innerHTML = 'Ranking+'; button.appendChild(buttonLink); var rankingMenu = document.getElementById('menu_ranking'); rankingMenu.parentNode.insertBefore(button, rankingMenu.nextSibling); function openWindow() { if (!unsafeWindow.AjaxWindow.windows[windowName]) { var win = document.createElement('div'); win.id = 'window_' + windowName; win.className = 'window'; unsafeWindow.AjaxWindow.windows[windowName] = win; var html = '\
\

Ranking+

\ \
\
\ '; win.innerHTML = html; win.style.zIndex = ++unsafeWindow.lastIndex; win.style.left = window.innerWidth / 2 - 365.5 + 'px'; document.getElementById('windows').appendChild(win); unsafeWindow.AjaxWindow.windows[windowName].makeDraggable(); win.addEventListener('mousedown', function() { win.style.zIndex = ++unsafeWindow.lastIndex; }.bind(win), false); printSortedTowns('allDuels'); } else { unsafeWindow.AjaxWindow.windows[windowName] = 'block'; unsafeWindow.AjaxWindow.windows[windowName] = ++unsafeWindow.lastIndex; } } function printSortedTowns(method) { towns.sort(function(a, b) { if (method === 'name') { return (a[method] > b[method]) ? 1 : ((b[method] > a[method]) ? -1 : 0); } return b[method] - a[method]; }); var win_content = document.getElementById('window_' + windowName + '_content'); clear(win_content); win_content.appendChild(renderWindowContent()); } function renderWindowContent() { var wrapper = document.createElement('div'); var updateTime = document.createElement('div'); updateTime.style.marginBottom = '5px'; var date = new Date(lastModified); updateTime.innerHTML = 'Last update: ' + date.toLocaleString(); var table = document.createElement('table'); table.id = 'ranking_table'; var trH = document.createElement('tr'); var headers = ['Town', 'All duels', 'Duels won', 'Duels lost', 'Diff', 'KO opponents', 'KO members', 'Highest counting hit in a duel', 'Best dueller of the town', 'Best duelling opponent']; var headersObj = ['name', 'allDuels', 'duelsWon', 'duelsLost', 'diff', 'koOpponents', 'koMembers', 'bestDmg', 'bestTownDmg', 'bestOpponentDmg']; for (var i = 0; i < headers.length; i++) { var th = document.createElement('th'); th.innerHTML = headers[i]; th.dataset.obj = headersObj[i]; th.addEventListener('click', function() { printSortedTowns(this.dataset.obj); }, false); trH.appendChild(th); } table.appendChild(trH); for (var j = 0; j < towns.length; j++) { var town = towns[j]; var tr = document.createElement('tr'); var td1 = document.createElement('td'); td1.innerHTML = town.town; tr.appendChild(td1); var td2 = document.createElement('td'); td2.className = 'bold'; td2.innerHTML = town.allDuels; tr.appendChild(td2); var td3 = document.createElement('td'); if (town.duelsWon > town.duelsLost) td3.className = 'green'; td3.innerHTML = town.duelsWon; tr.appendChild(td3); var td4 = document.createElement('td'); if (town.duelsLost > town.duelsWon) td4.className = 'red'; td4.innerHTML = town.duelsLost; tr.appendChild(td4); var td5 = document.createElement('td'); td5.innerHTML = town.diff; tr.appendChild(td5); var td6 = document.createElement('td'); if (town.koOpponents > town.koMembers) td6.className = 'green'; td6.innerHTML = town.koOpponents; tr.appendChild(td6); var td7 = document.createElement('td'); if (town.koMembers > town.koOpponents) td7.className = 'red'; td7.innerHTML = town.koMembers; tr.appendChild(td7); var td8 = document.createElement('td'); td8.innerHTML = (town.bestDmg > 0 ? town.bestDmg + ' dmg
' + town.bestPlayer : '-'); tr.appendChild(td8); var td9 = document.createElement('td'); td9.innerHTML = (town.bestTownDmg > 0 ? town.bestTownDmg + ' dmg
' + town.bestTownPlayer : '-'); tr.appendChild(td9); var td10 = document.createElement('td'); td10.innerHTML = (town.bestOpponentDmg > 0 ? town.bestOpponentDmg + ' dmg
' + town.bestOpponentPlayer : '-'); tr.appendChild(td10); table.appendChild(tr); } wrapper.appendChild(updateTime); wrapper.appendChild(table); return wrapper; } function clear(el) { while (el.firstChild) el.removeChild(el.firstChild); } })();