webadmin 1.8.2
This commit is contained in:
@@ -11,6 +11,91 @@ function floodprotection_change() {
|
||||
}
|
||||
}
|
||||
|
||||
function make_sortable_table(table) {
|
||||
if (table.rows.length >= 1) { // Ensure that the table at least contains a row for the headings
|
||||
var headings = table.rows[0].getElementsByTagName("th");
|
||||
for (var i = 0; i < headings.length; i++) {
|
||||
// This function acts to scope the i variable, so we can pass it off
|
||||
// as the column_index, otherwise column_index would just be the max
|
||||
// value of i, every single time.
|
||||
(function (i) {
|
||||
var heading = headings[i];
|
||||
if (!heading.classList.contains("ignore-sort")) {
|
||||
heading.addEventListener("click", function () { // Bind a click event to the heading
|
||||
sort_table(this, i, table, headings);
|
||||
});
|
||||
}
|
||||
})(i);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function sort_table(clicked_column, column_index, table, headings) {
|
||||
for (var i = 0; i < headings.length; i++) {
|
||||
if (headings[i] != clicked_column) {
|
||||
headings[i].classList.remove("sorted");
|
||||
headings[i].classList.remove("reverse-sorted");
|
||||
}
|
||||
}
|
||||
var reverse = false;
|
||||
clicked_column.classList.toggle("reverse");
|
||||
if (clicked_column.classList.contains("sorted")) {
|
||||
reverse = true;
|
||||
clicked_column.classList.remove("sorted");
|
||||
clicked_column.classList.add("reverse-sorted");
|
||||
} else {
|
||||
clicked_column.classList.remove("reverse-sorted");
|
||||
clicked_column.classList.add("sorted");
|
||||
}
|
||||
|
||||
// This array will contain tuples in the form [(value, row)] where value
|
||||
// is extracted from the column to be sorted by
|
||||
var rows_and_sortable_value = [];
|
||||
for (var i = 1, row; row = table.rows[i]; i++) {
|
||||
for (var j = 0, col; col = row.cells[j]; j++) {
|
||||
// If we're at the column index we want to sort by
|
||||
if (j === column_index) {
|
||||
var cell = row.getElementsByTagName("td")[j];
|
||||
var value = cell.innerHTML;
|
||||
rows_and_sortable_value.push([value, row]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
rows_and_sortable_value.sort(function (a, b) {
|
||||
// If both values are integers, sort by that else as strings
|
||||
if (isInt(a[0]) && isInt(b[0])) {
|
||||
return a[0] - b[0];
|
||||
} else {
|
||||
return b[0].localeCompare(a[0]);
|
||||
}
|
||||
});
|
||||
if (reverse) {
|
||||
rows_and_sortable_value.reverse();
|
||||
}
|
||||
|
||||
var parent = table.rows[1].parentNode;
|
||||
for (var i = 0; i < rows_and_sortable_value.length; i++) {
|
||||
// Remove the existing entry for the row from the table
|
||||
parent.removeChild(rows_and_sortable_value[i][1]);
|
||||
// Insert at the first position, before the first child
|
||||
parent.insertBefore(rows_and_sortable_value[i][1], parent.firstChild);
|
||||
}
|
||||
}
|
||||
|
||||
function isInt(value) {
|
||||
return !isNaN(value) && (function (x) {
|
||||
return (x | 0) === x;
|
||||
})(parseFloat(value))
|
||||
}
|
||||
|
||||
function make_sortable() {
|
||||
var tables = document.querySelectorAll("table.sortable");
|
||||
for (var i = 0; i < tables.length; i++) {
|
||||
make_sortable_table(tables[i]);
|
||||
}
|
||||
}
|
||||
|
||||
function serverlist_init($) {
|
||||
function serialize() {
|
||||
var text = "";
|
||||
@@ -19,7 +104,7 @@ function serverlist_init($) {
|
||||
var port = $(".servers_row_port", $(this)).val();
|
||||
var ssl = $(".servers_row_ssl", $(this)).is(":checked");
|
||||
var pass = $(".servers_row_pass", $(this)).val();
|
||||
if (host.length == 0) return;
|
||||
if (host == undefined) return;
|
||||
text += host;
|
||||
text += " ";
|
||||
if (ssl) text += "+";
|
||||
@@ -76,12 +161,9 @@ function serverlist_init($) {
|
||||
|
||||
$("#servers_plain").hide();
|
||||
$("#servers_js").show();
|
||||
})();
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
|
||||
/* Broken. Work is in progress... Hang in there cowboy/girl...
|
||||
function ctcpreplies_init($) {
|
||||
function serialize() {
|
||||
var text = "";
|
||||
@@ -104,13 +186,13 @@ function ctcpreplies_init($) {
|
||||
}
|
||||
row.append(
|
||||
$("<td/>").append($("<input/>").val(request)
|
||||
.addClass("ctcpreplies_row_request")
|
||||
.addClass("form-control ctcpreplies_row_request")
|
||||
.attr({"type":"text","list":"ctcpreplies_list"})),
|
||||
$("<td/>").append($("<input/>").val(response)
|
||||
.addClass("ctcpreplies_row_response")
|
||||
.addClass("form-control ctcpreplies_row_response")
|
||||
.attr({"type":"text","placeholder":"Empty value means this CTCP request will be ignored"})),
|
||||
$("<td/>").append($("<button/>").val("X")
|
||||
.attr({"type":"button"}).addClass("btn btn-default").click(delete_row))
|
||||
$("<td/>").append($("<input/>").val("X")
|
||||
.addClass("btn btn-danger").val("X").css({width: '40px'}).click(delete_row))
|
||||
);
|
||||
$("input", row).change(serialize);
|
||||
$("#ctcpreplies_tbody").append(row);
|
||||
@@ -140,4 +222,3 @@ function ctcpreplies_init($) {
|
||||
$("#ctcpreplies_js").show();
|
||||
})();
|
||||
}
|
||||
*/
|
||||
|
138
modules/webadmin/files/webadmin2.js
Normal file
138
modules/webadmin/files/webadmin2.js
Normal file
@@ -0,0 +1,138 @@
|
||||
function floodprotection_change() {
|
||||
var protection = document.getElementById('floodprotection_checkbox');
|
||||
var rate = document.getElementById('floodrate');
|
||||
var burst = document.getElementById('floodburst');
|
||||
if (protection.checked) {
|
||||
rate.removeAttribute('disabled');
|
||||
burst.removeAttribute('disabled');
|
||||
} else {
|
||||
rate.disabled = 'disabled';
|
||||
burst.disabled = 'disabled';
|
||||
}
|
||||
}
|
||||
|
||||
function serverlist_init($) {
|
||||
function serialize() {
|
||||
var text = "";
|
||||
$("#servers_tbody > tr").each(function() {
|
||||
var host = $(".servers_row_host", $(this)).val();
|
||||
var port = $(".servers_row_port", $(this)).val();
|
||||
var ssl = $(".servers_row_ssl", $(this)).is(":checked");
|
||||
var pass = $(".servers_row_pass", $(this)).val();
|
||||
if (host == undefined) return;
|
||||
text += host;
|
||||
text += " ";
|
||||
if (ssl) text += "+";
|
||||
text += port;
|
||||
text += " ";
|
||||
text += pass;
|
||||
text += "\n";
|
||||
});
|
||||
$("#servers_text").val(text);
|
||||
}
|
||||
function add_row(host, port, ssl, pass) {
|
||||
var row = $("<tr/>");
|
||||
function delete_row() {
|
||||
row.remove();
|
||||
serialize();
|
||||
}
|
||||
row.append(
|
||||
$("<td/>").append($("<input/>").attr({"type":"text"})
|
||||
.addClass("form-control servers_row_host").val(host)),
|
||||
$("<td/>").append($("<input/>").attr({"type":"number"})
|
||||
.addClass("form-control servers_row_port").val(port)),
|
||||
$("<td/>").append($("<input/>").attr({"type":"checkbox"})
|
||||
.addClass("servers_row_ssl").prop("checked", ssl)),
|
||||
$("<td/>").append($("<input/>").attr({"type":"text"})
|
||||
.addClass("form-control servers_row_pass").val(pass)),
|
||||
$("<td/>").append($("<input/>").attr({"type":"button"})
|
||||
.addClass("btn btn-danger").val("X").click(delete_row))
|
||||
);
|
||||
$("input", row).change(serialize);
|
||||
$("#servers_tbody").append(row);
|
||||
}
|
||||
|
||||
var servers_text = $("#servers_text").val();
|
||||
// Parse it
|
||||
$.each(servers_text.split("\n"), function(i, line) {
|
||||
if (line.length == 0) return;
|
||||
line = line.split(" ");
|
||||
var host = line[0];
|
||||
var port = line[1] || "6667";
|
||||
var pass = line[2] || "";
|
||||
var ssl;
|
||||
if (port.match(/^\+/)) {
|
||||
ssl = true;
|
||||
port = port.substr(1);
|
||||
} else {
|
||||
ssl = false;
|
||||
}
|
||||
add_row(host, port, ssl, pass);
|
||||
});
|
||||
$("#servers_add").click(function() {
|
||||
add_row("", 6697, true, "");
|
||||
// Not serializing, because empty host doesn't emit anything anyway
|
||||
});
|
||||
|
||||
$("#servers_plain").hide();
|
||||
$("#servers_js").show();
|
||||
};
|
||||
|
||||
function ctcpreplies_init($) {
|
||||
function serialize() {
|
||||
var text = "";
|
||||
$("#ctcpreplies_tbody > tr").each(function() {
|
||||
var request = $(".ctcpreplies_row_request", $(this)).val();
|
||||
var response = $(".ctcpreplies_row_response", $(this)).val();
|
||||
if (request.length == 0) return;
|
||||
text += request;
|
||||
text += " ";
|
||||
text += response;
|
||||
text += "\n";
|
||||
});
|
||||
$("#ctcpreplies_text").val(text);
|
||||
}
|
||||
function add_row(request, response) {
|
||||
var row = $("<tr/>");
|
||||
function delete_row() {
|
||||
row.remove();
|
||||
serialize();
|
||||
}
|
||||
row.append(
|
||||
$("<td/>").append($("<input/>").attr({"type":"text"})
|
||||
.addClass("form-control servers_row_host").val(host)),
|
||||
$("<td/>").append($("<input/>").attr({"type":"number"})
|
||||
.addClass("form-control servers_row_port").val(port)),
|
||||
$("<td/>").append($("<input/>").attr({"type":"checkbox"})
|
||||
.addClass("servers_row_ssl").prop("checked", ssl)),
|
||||
$("<td/>").append($("<input/>").attr({"type":"button"})
|
||||
.addClass("btn btn-danger").val("X").click(delete_row))
|
||||
);
|
||||
$("input", row).change(serialize);
|
||||
$("#ctcpreplies_tbody").append(row);
|
||||
}
|
||||
|
||||
(function() {
|
||||
var replies_text = $("#ctcpreplies_text").val();
|
||||
$.each(replies_text.split("\n"), function(i, line) {
|
||||
if (line.length == 0) return;
|
||||
var space = line.indexOf(" ");
|
||||
var request;
|
||||
var response;
|
||||
if (space == -1) {
|
||||
request = line;
|
||||
response = "";
|
||||
} else {
|
||||
request = line.substr(0, space);
|
||||
response = line.substr(space + 1);
|
||||
}
|
||||
add_row(request, response);
|
||||
});
|
||||
$("#ctcpreplies_add").click(function() {
|
||||
add_row("", "");
|
||||
});
|
||||
|
||||
$("#ctcpreplies_plain").hide();
|
||||
$("#ctcpreplies_js").show();
|
||||
})();
|
||||
}
|
Reference in New Issue
Block a user