mirror of https://github.com/calzoneman/sync.git
Paginate user table in ACP
This commit is contained in:
parent
6943845d7a
commit
71b774b445
4
acp.js
4
acp.js
|
@ -137,8 +137,8 @@ module.exports = {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
user.socket.on("acp-actionlog-clear", function() {
|
user.socket.on("acp-actionlog-clear", function(data) {
|
||||||
ActionLog.clear();
|
ActionLog.clear(data);
|
||||||
ActionLog.record(user.ip, user.name, "acp-actionlog-clear");
|
ActionLog.record(user.ip, user.name, "acp-actionlog-clear");
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -150,10 +150,10 @@
|
||||||
<table class="table table-striped table-bordered">
|
<table class="table table-striped table-bordered">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th>UID</th>
|
<th id="userlookup_uid">UID</th>
|
||||||
<th>Name</th>
|
<th id="userlookup_uname">Name</th>
|
||||||
<th>Global Rank</th>
|
<th id="userlookup_rank">Global Rank</th>
|
||||||
<th>Email</th>
|
<th id="userlookup_email">Email</th>
|
||||||
<th>Password Reset</th>
|
<th>Password Reset</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
|
|
|
@ -41,6 +41,26 @@ menuHandler("#show_logview", "#logview");
|
||||||
menuHandler("#show_announce", "#announcepanel");
|
menuHandler("#show_announce", "#announcepanel");
|
||||||
menuHandler("#show_gbans", "#gbanpanel");
|
menuHandler("#show_gbans", "#gbanpanel");
|
||||||
menuHandler("#show_userlookup", "#userlookup");
|
menuHandler("#show_userlookup", "#userlookup");
|
||||||
|
function tableResort(tbl, sortby) {
|
||||||
|
if(tbl.data("sortby") == sortby)
|
||||||
|
tbl.data("sort_desc", !tbl.data("sort_desc"));
|
||||||
|
else
|
||||||
|
tbl.data("sortby", sortby)
|
||||||
|
loadPage(tbl, 0);
|
||||||
|
}
|
||||||
|
$("#userlookup_uid").click(function() {
|
||||||
|
tableResort($("#userlookup table"), "id");
|
||||||
|
});
|
||||||
|
$("#userlookup_uname").click(function() {
|
||||||
|
tableResort($("#userlookup table"), "uname");
|
||||||
|
});
|
||||||
|
$("#userlookup_rank").click(function() {
|
||||||
|
tableResort($("#userlookup table"), "global_rank");
|
||||||
|
});
|
||||||
|
$("#userlookup_email").click(function() {
|
||||||
|
tableResort($("#userlookup table"), "email");
|
||||||
|
});
|
||||||
|
|
||||||
menuHandler("#show_chanloaded", "#channellist");
|
menuHandler("#show_chanloaded", "#channellist");
|
||||||
$("#show_chanloaded").click(function() {
|
$("#show_chanloaded").click(function() {
|
||||||
socket.emit("acp-list-loaded");
|
socket.emit("acp-list-loaded");
|
||||||
|
@ -151,6 +171,41 @@ $("#userlookup_submit").click(function() {
|
||||||
socket.emit("acp-lookup-user", $("#userlookup_name").val());
|
socket.emit("acp-lookup-user", $("#userlookup_name").val());
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function loadPage(tbl, page) {
|
||||||
|
var sort_field = tbl.data("sortby");
|
||||||
|
var sort_desc = tbl.data("sort_desc");
|
||||||
|
var generator = tbl.data("generator");
|
||||||
|
var pag = tbl.data("pagination");
|
||||||
|
if(pag) {
|
||||||
|
pag.find("li").each(function() {
|
||||||
|
$(this).removeClass("active");
|
||||||
|
});
|
||||||
|
$(pag.find("li")[page]).addClass("active");
|
||||||
|
}
|
||||||
|
var e = tbl.data("entries");
|
||||||
|
|
||||||
|
tbl.find("tbody").remove();
|
||||||
|
|
||||||
|
if(sort_field) {
|
||||||
|
e.sort(function(a, b) {
|
||||||
|
var x = a[sort_field];
|
||||||
|
if(typeof x == "string")
|
||||||
|
x = x.toLowerCase();
|
||||||
|
var y = b[sort_field];
|
||||||
|
if(typeof y == "string")
|
||||||
|
y = y.toLowerCase();
|
||||||
|
var z = x == y ? 0 : (x < y ? -1 : 1);
|
||||||
|
if(sort_desc)
|
||||||
|
z = -z;
|
||||||
|
return z;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
for(var i = page * 20; i < page * 20 + 20; i++) {
|
||||||
|
generator(e[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function setupCallbacks() {
|
function setupCallbacks() {
|
||||||
socket.on("connect", function() {
|
socket.on("connect", function() {
|
||||||
if(NAME && SESSION) {
|
if(NAME && SESSION) {
|
||||||
|
@ -213,21 +268,34 @@ function setupCallbacks() {
|
||||||
});
|
});
|
||||||
|
|
||||||
socket.on("acp-userdata", function(data) {
|
socket.on("acp-userdata", function(data) {
|
||||||
data = data.sort(function(a, b) {
|
var tbl = $("#userlookup table");
|
||||||
var x = a.uname.toLowerCase();
|
if(data.length > 20) {
|
||||||
var y = b.uname.toLowerCase();
|
var pag = $("<div/>").addClass("pagination")
|
||||||
return x == y ? 0 : (x < y ? -1 : 1);
|
.attr("id", "userlookup_pagination")
|
||||||
});
|
.insertAfter($("#userlookup table"));
|
||||||
|
var btns = $("<ul/>").appendTo(pag);
|
||||||
$("#userlookup tbody").remove();
|
for(var i = 0; i < data.length / 20; i++) {
|
||||||
for(var i = 0; i < data.length; i++) {
|
var li = $("<li/>").appendTo(btns);
|
||||||
var u = data[i];
|
(function(i) {
|
||||||
|
$("<a/>").attr("href", "javascript:void(0)")
|
||||||
|
.text(i+1)
|
||||||
|
.click(function() {
|
||||||
|
loadPage(tbl, i);
|
||||||
|
})
|
||||||
|
.appendTo(li);
|
||||||
|
})(i);
|
||||||
|
}
|
||||||
|
tbl.data("pagination", pag);
|
||||||
|
}
|
||||||
|
tbl.data("entries", data);
|
||||||
|
tbl.data("sortby", "uname");
|
||||||
|
tbl.data("sort_desc", false);
|
||||||
|
tbl.data("generator", function(u) {
|
||||||
var tr = $("<tr/>").appendTo($("#userlookup table"));
|
var tr = $("<tr/>").appendTo($("#userlookup table"));
|
||||||
$("<td/>").text(u.id).appendTo(tr);
|
$("<td/>").text(u.id).appendTo(tr);
|
||||||
$("<td/>").text(u.uname).appendTo(tr);
|
$("<td/>").text(u.uname).appendTo(tr);
|
||||||
var rank = $("<td/>").text(u.global_rank).appendTo(tr);
|
var rank = $("<td/>").text(u.global_rank).appendTo(tr);
|
||||||
$("<td/>").text(u.email).appendTo(tr);
|
$("<td/>").text(u.email).appendTo(tr);
|
||||||
(function(name, email) {
|
|
||||||
$("<button/>").addClass("btn btn-mini")
|
$("<button/>").addClass("btn btn-mini")
|
||||||
.text("Reset password")
|
.text("Reset password")
|
||||||
.appendTo($("<td/>").appendTo(tr))
|
.appendTo($("<td/>").appendTo(tr))
|
||||||
|
@ -235,43 +303,41 @@ function setupCallbacks() {
|
||||||
var reset = confirm("Really reset password?");
|
var reset = confirm("Really reset password?");
|
||||||
if(reset) {
|
if(reset) {
|
||||||
socket.emit("acp-reset-password", {
|
socket.emit("acp-reset-password", {
|
||||||
name: name,
|
name: u.uname,
|
||||||
email: email
|
email: u.email
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
})(u.uname, u.email);
|
rank.click(function() {
|
||||||
(function(u) {
|
if(this.find(".rank-edit").length > 0)
|
||||||
rank.click(function() {
|
return;
|
||||||
if(this.find(".rank-edit").length > 0)
|
var r = this.text();
|
||||||
return;
|
this.text("");
|
||||||
var r = this.text();
|
var edit = $("<input/>").attr("type", "text")
|
||||||
this.text("");
|
.attr("placeholder", r)
|
||||||
var edit = $("<input/>").attr("type", "text")
|
.addClass("rank-edit")
|
||||||
.attr("placeholder", r)
|
.appendTo(this)
|
||||||
.addClass("rank-edit")
|
.focus();
|
||||||
.appendTo(this)
|
|
||||||
.focus();
|
|
||||||
|
|
||||||
function save() {
|
function save() {
|
||||||
var r = this.val();
|
var r = this.val();
|
||||||
var r2 = r;
|
var r2 = r;
|
||||||
if(r.trim() == "")
|
if(r.trim() == "")
|
||||||
r = this.attr("placeholder");
|
r = this.attr("placeholder");
|
||||||
this.parent().text(this.attr("placeholder"));
|
this.parent().text(this.attr("placeholder"));
|
||||||
socket.emit("acp-set-rank", {
|
socket.emit("acp-set-rank", {
|
||||||
name: u.uname,
|
name: u.uname,
|
||||||
rank: parseInt(r)
|
rank: parseInt(r)
|
||||||
});
|
|
||||||
}
|
|
||||||
edit.blur(save.bind(edit));
|
|
||||||
edit.keydown(function(ev) {
|
|
||||||
if(ev.keyCode == 13)
|
|
||||||
save.bind(edit)();
|
|
||||||
});
|
});
|
||||||
}.bind(rank));
|
}
|
||||||
})(u);
|
edit.blur(save.bind(edit));
|
||||||
}
|
edit.keydown(function(ev) {
|
||||||
|
if(ev.keyCode == 13)
|
||||||
|
save.bind(edit)();
|
||||||
|
});
|
||||||
|
}.bind(rank));
|
||||||
|
});
|
||||||
|
loadPage($("#userlookup table"), 0);
|
||||||
});
|
});
|
||||||
|
|
||||||
socket.on("acp-set-rank", function(data) {
|
socket.on("acp-set-rank", function(data) {
|
||||||
|
|
Loading…
Reference in New Issue