diff options
Diffstat (limited to 'util/master/list.js')
-rw-r--r-- | util/master/list.js | 111 |
1 files changed, 75 insertions, 36 deletions
diff --git a/util/master/list.js b/util/master/list.js index a17458fb4..b5974619a 100644 --- a/util/master/list.js +++ b/util/master/list.js @@ -1,7 +1,13 @@ var master_root, output_to; +var master; +if (!master) master = { + root: master_root, + output: output_to +}; function e(s) { if (typeof s === "undefined") s = ''; + if (typeof s === "number") return s; return s.replace(/&/g, '&').replace(/</g, '<').replace(/>/g, '>').replace(/"/g, '"'); //mc" } @@ -41,55 +47,88 @@ function human_time(t, abs) { function success(r) { if (!r || !r.list) return; - var h = '<table class="mts_table"><tr class="mts_head"><th>ip[:port]</th><th>clients/max</th><th>version gameid mapgen</th><th>name</th><th>description</th><th>flags</th><th>uptime</th><th>ping</th></tr>'; + var h = ''; + if (!master.no_total && r.total) + h += '<div class="mts_total">Now players: ' + r.total.clients + ' servers: ' + r.total.servers + '</div>'; + if (!master.no_total_max && r.total_max) + h += '<div class="mts_total_max">Max players: ' + r.total_max.clients + ' servers: ' + r.total_max.servers + '</div>'; + h += '<table class="mts_table">'; + if (r.list.length) { + h += '<tr class="mts_head">'; + if (!master.no_address) h += '<th>ip[:port]</th>'; + if (!master.no_clients) h += '<th>players/max</th>'; + if (!master.no_version) h += '<th>version gameid mapgen</th>'; + if (!master.no_name) h += '<th>name</th>'; + if (!master.no_description) h += '<th>description</th>'; + if (!master.no_flags) h += '<th>flags</th>'; + if (!master.no_uptime) h += '<th>uptime age</th>'; + if (!master.no_ping) h += '<th>ping</th>'; + h += '</tr>'; + } + var count = 0; for (var i = 0; i < r.list.length; ++i) { + if (++count > master.limit && master.limit) break; var s = r.list[i]; if (!s) continue; + if (master.clients_min && s.clients < master.clients_min) continue; if (/:/.test(s.address)) s.address = '[' + s.address + ']'; h += '<tr class="mts_row">'; - h += '<td class="mts_address">' + e(s.address) + (s.port != 30000 ? (':' + e(s.port)) : '') + '</td>'; - h += '<td class="mts_clients">' + e(s.clients) + (s.clients_max ? '/' + e(s.clients_max) : '') + (s.clients_top ? ', ' + e(s.clients_top) : '') + '</td>'; + if (!master.no_address) h += '<td class="mts_address">' + e(s.address) + (s.port != 30000 ? (':' + e(s.port)) : '') + '</td>'; + if (!master.no_clients) { + h += '<td class="mts_clients' + (s.clients && s.clients_list ? ' mts_is_clients' : '') + '">'; + if (!master.no_clients_list && s.clients && s.clients_list) { + h += '<div class="mts_clients_list">Players (' + e(s.clients) + '):<br/>'; + for (var ii in s.clients_list) + h += e(s.clients_list[ii]) + '<br/>'; + h += '</div>'; + } + h += e(s.clients) + (s.clients_max ? '/' + e(s.clients_max) : '') + (s.clients_top ? ', ' + e(s.clients_top) : '') + '</td>'; + } var mods = 0; - if (s.mods && jQuery.isArray(s.mods)) { + if (s.mods && jQuery.isArray(s.mods)) mods = s.mods.length; - } - h += '<td class="mts_version' + (mods ? ' mts_ismods' : '') + '">' + e(s.version) + ' ' + e(s.gameid) + ' ' + e(s.mapgen); - if (mods) { - h += '<div class="mts_mods">Mods ('+mods+'):<br/>'; - for (m in s.mods) { - h += s.mods[m] + '<br/>'; + if (!master.no_version) { + h += '<td class="mts_version' + (mods ? ' mts_is_mods' : '') + '">' + e(s.version) + ' ' + e(s.gameid) + ' ' + e(s.mapgen); + if (!master.no_mods && mods) { + h += '<div class="mts_mods">Mods (' + mods + '):<br/>'; + for (var ii in s.mods) + h += e(s.mods[ii]) + '<br/>'; + h += '</div>'; } - h += '</div>'; + h += '</td>'; + } + if (!master.no_name) { + h += '<td class="mts_url">'; + if (s.url) h += '<a href="' + e(s.url) + '">'; + h += e(s.name || s.url); + if (s.url) h += '</a>'; + h += '</td>'; + } + if (!master.no_description) h += '<td class="mts_description">' + e(s.description) + '</td>'; + if (!master.no_flags) { + h += '<td class="mts_flags">' + + (s.password ? 'Pwd ' : '') + + (s.creative ? 'Cre ' : '') + + (s.damage ? 'Dmg ' : '') + + (s.pvp ? 'Pvp ' : '') + + (s.dedicated ? 'Ded ' : '') + + (s.rollback ? 'Rol ' : '') + + (s.liquid_finite ? 'Liq ' : '') + + '</td>'; } - - h += '</td>'; - - h += '<td class="mts_url">'; - if (s.url) h += '<a href="' + e(s.url) + '">'; - h += e(s.name || s.url); - if (s.url) h += '</a>'; - h += '</td>'; - h += '<td class="mts_description">' + e(s.description) + '</td>'; - h += '<td class="mts_flags">' + - (s.password ? 'Pwd ' : '') + - (s.creative ? 'Cre ' : '') + - (s.damage ? 'Dmg ' : '') + - (s.pvp ? 'Pvp ' : '') + - (s.dedicated ? 'Ded ' : '') + - (s.rollback ? 'Rol ' : '') + - (s.liquid_finite ? 'Liq ' : '') + - '</td>'; if (!s.start || s.start < 0) s.start = 0; - h += '<td class="mts_time">' + (s.uptime ? human_time(s.uptime, 1) : s.start ? human_time(s.start) : '') + '</td>'; - h += '<td class="mts_ping">' + (s.ping ? parseFloat(s.ping).toFixed(3) * 1000 : '') + '</td>'; + if (!master.no_uptime) h += '<td class="mts_uptime">' + (s.uptime ? human_time(s.uptime, 1) : s.start ? human_time(s.start) : '') + (s.game_time ? ' ' + human_time(s.game_time, 1) : '') + '</td>'; + if (!master.no_ping) h += '<td class="mts_ping">' + (s.ping ? parseFloat(s.ping).toFixed(3) * 1000 : '') + '</td>'; h += '</tr>'; } - h += '</table>' - jQuery(output_to || '#servers_table').html(h); + h += '</table>'; + if (master.clients_min || master.limit) + h += '<a href="#" onclick="delete master.limit;delete master.clients_min; get(1);">more...</a>'; + jQuery(master.output || '#servers_table').html(h); } -function get() { - jQuery.getJSON((master_root || '') + 'list', success); - setTimeout(get, 60000); +function get(refresh) { + jQuery.getJSON((master.root || '') + 'list', success); + if (!refresh && !master.no_refresh) setTimeout(get, 60000); } get(); |