';
}
@@ -67,12 +68,18 @@ function hoverList(name, list) {
function hoverString(name, string) {
if (!string) return '';
- return '
'
- + name + ':
'
+ return '
'
+ + '' + name + ':
'
+ escapeHTML(string) + '
'
+ '
';
}
+function constantWidth(str, width) {
+ return '
' + str + '';
+}
+
+// Code that fetches & displays the actual list
+
function draw(json) {
var html = window.render.servers(json);
jQuery(master.output).html(html);
@@ -89,6 +96,7 @@ function loaded(){
get();
}
+
// https://github.com/pyrsmk/toast
this.toast=function(){var e=document,t=e.getElementsByTagName("head")[0],n=this.setTimeout,r="createElement",i="appendChild",s="addEventListener",o="onreadystatechange",u="styleSheet",a=10,f=0,l=function(){--f},c,h=function(e,r,i,s){if(!t)n(function(){h(e)},a);else if(e.length){c=-1;while(i=e[++c]){if((s=typeof i)=="function"){r=function(){return i(),!0};break}if(s=="string")p(i);else if(i.pop){p(i[0]),r=i[1];break}}d(r,Array.prototype.slice.call(e,c+1))}},p=function(n,s){++f,/\.css$/.test(n)?(s=e[r]("link"),s.rel=u,s.href=n,t[i](s),v(s)):(s=e[r]("script"),s.src=n,t[i](s),s[o]===null?s[o]=m:s.onload=l)},d=function(e,t){if(!f)if(!e||e()){h(t);return}n(function(){d(e,t)},a)},v=function(e){if(e.sheet||e[u]){l();return}n(function(){v(e)},a)},m=function(){/ded|co/.test(this.readyState)&&l()};h(arguments)};
@@ -96,6 +104,6 @@ toast(master.root + 'style.css', master.root + 'servers.js', function() {
if (typeof(jQuery) != 'undefined')
return loaded();
else
- toast('//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js', loaded);
+ toast('//ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js', loaded);
});
diff --git a/static/servers.jst b/static/servers.jst
index deaa9b3..c749b25 100644
--- a/static/servers.jst
+++ b/static/servers.jst
@@ -8,7 +8,7 @@
{{? !master.no_address}}| Address[:Port] | {{?}}
{{? !master.no_clients}}Players / Max{{? !master.no_avgtop}} Average / Top{{?}} | {{?}}
- {{? !master.no_version}}Version, Subgame, Mapgenerator | {{?}}
+ {{? !master.no_version}}Version, Subgame[, Mapgen] | {{?}}
{{? !master.no_name}}Name | {{?}}
{{? !master.no_description}}Description | {{?}}
{{? !master.no_flags}}Flags | {{?}}
@@ -26,13 +26,14 @@
{{?}}
{{? !master.no_clients}}
- {{=server.clients}}/{{=server.clients_max}}{{? !master.no_avgtop}} {{=Math.floor(server.pop_v)}}/{{=server.clients_top}}{{?}}
+ {{=constantWidth(server.clients + '/' + server.clients_max, 3.4)}}
+ {{? !master.no_avgtop}} {{=constantWidth(Math.floor(server.pop_v) + '/' + server.clients_top, 3.4)}}{{?}}
{{=hoverList("Clients", server.clients_list)}}
| {{?}}
{{? !master.no_version}}
- {{=escapeHTML(server.version)}}, {{=escapeHTML(server.gameid)}},
- {{=escapeHTML(server.mapgen || '?')}}
+ {{=escapeHTML(server.version)}}, {{=escapeHTML(server.gameid)}}
+ {{? server.mapgen}}, {{=escapeHTML(server.mapgen)}}{{?}}
{{=hoverList("Mods", server.mods)}}
| {{?}}
{{? !master.no_name}}
@@ -51,9 +52,7 @@
{{=hoverString("Privs", server.privs)}}
{{=server.creative ? 'Cre ' : ''}}
- {{=server.dedicated ? 'Ded ' : ''}}
{{=server.damage ? 'Dmg ' : ''}}
- {{=server.liquid_finite ? 'Liq ' : ''}}
{{=server.pvp ? 'PvP ' : ''}}
{{=server.password ? 'Pwd ' : ''}}
{{=server.rollback ? 'Rol ' : ''}}
@@ -61,11 +60,11 @@
| {{?}}
{{? !master.no_uptime}}
- {{=humanTime(server.uptime)}}, {{=humanTime(server.game_time)}}
+ {{=constantWidth(humanTime(server.uptime), 3.2)}} / {{=constantWidth(humanTime(server.game_time), 3.2)}}
| {{?}}
{{? !master.no_ping}}
- {{=Math.floor(server.ping * 1000)}}{{? server.lag}}, {{= Math.floor(server.lag * 1000)}}{{?}}
+ {{=constantWidth(Math.floor(server.ping * 1000), 1.8)}}{{? server.lag}} / {{=constantWidth(Math.floor(server.lag * 1000), 1.8)}}{{?}}
| {{?}}
{{~}}
diff --git a/static/style.css b/static/style.css
index fc6206d..e33f470 100644
--- a/static/style.css
+++ b/static/style.css
@@ -20,11 +20,7 @@
}
#server_list tbody tr:nth-child(even) {
- background-color: #EEE;
-}
-
-#server_list tbody tr:hover {
- background-color: #CCC;
+ background-color: #F1F1F1;
}
.mts_hover_list {
@@ -41,13 +37,18 @@ td:hover .mts_hover_list {
display: block;
}
-.mts_hover_list_text, .mts_tooltip {
- text-decoration: underline;
- text-decoration-style: dashed;
-}
-
.clickable {
text-decoration: underline;
cursor: pointer;
}
+.mts_tooltip {
+ text-overflow: ellipsis;
+ overflow: hidden;
+ white-space: nowrap;
+}
+
+.mts_cwidth {
+ display: inline-block;
+ text-align: center;
+}