pgweb/static/js/app.js

512 lines
12 KiB
JavaScript
Raw Normal View History

var editor;
2014-11-02 04:06:15 +03:00
var connected = false;
function apiCall(method, path, params, cb) {
2014-10-13 22:55:19 +04:00
$.ajax({
url: path,
method: method,
2014-10-13 22:55:19 +04:00
cache: false,
data: params,
2014-10-13 22:55:19 +04:00
success: function(data) {
cb(data);
},
error: function(xhr, status, data) {
cb(jQuery.parseJSON(xhr.responseText));
}
});
}
function getTables(cb) { apiCall("get", "/tables", {}, cb); }
function getTableStructure(table, cb) { apiCall("get", "/tables/" + table, {}, cb); }
function getTableIndexes(table, cb) { apiCall("get", "/tables/" + table + "/indexes", {}, cb); }
function getHistory(cb) { apiCall("get", "/history", {}, cb); }
function executeQuery(query, cb) {
apiCall("post", "/query", { query: query }, cb);
}
function explainQuery(query, cb) {
apiCall("post", "/explain", { query: query }, cb);
}
2014-10-13 22:55:19 +04:00
function loadTables() {
$("#tables li").remove();
2014-10-13 22:55:19 +04:00
getTables(function(data) {
data.forEach(function(item) {
$("<li><span><i class='fa fa-table'></i> " + item + "</span></li>").appendTo("#tables");
2014-10-13 22:55:19 +04:00
});
});
}
2014-10-14 04:49:43 +04:00
function escapeHtml(str) {
if (str != null || str != undefined) {
return jQuery("<div/>").text(str).html();
}
return "<span class='null'>null</span>";
}
function unescapeHtml(str){
var e = document.createElement("div");
e.innerHTML = str;
return e.childNodes.length === 0 ? "" : e.childNodes[0].nodeValue;
}
2014-12-02 05:51:20 +03:00
function getCurrentTable() {
return $("#tables").attr("data-current") || "";
2014-12-02 05:51:20 +03:00
}
function resetTable() {
$("#results").
attr("data-mode", "").
text("").
2014-10-26 00:18:30 +04:00
removeClass("empty").
removeClass("no-crop");
}
2014-10-13 22:55:19 +04:00
function buildTable(results) {
resetTable();
2014-10-13 22:55:19 +04:00
if (results.error) {
$("<tr><td>ERROR: " + results.error + "</tr></tr>").appendTo("#results");
$("#results").addClass("empty");
return;
}
if (!results.rows) {
$("<tr><td>No records found</tr></tr>").appendTo("#results");
$("#results").addClass("empty");
return;
}
var cols = "";
2014-10-26 00:18:30 +04:00
var rows = "";
2014-10-13 22:55:19 +04:00
results.columns.forEach(function(col) {
cols += "<th data='" + col + "'>" + col + "</th>";
2014-10-13 22:55:19 +04:00
});
results.rows.forEach(function(row) {
var r = "";
2014-10-14 04:49:43 +04:00
for (i in row) { r += "<td><div>" + escapeHtml(row[i]) + "</div></td>"; }
2014-10-13 22:55:19 +04:00
rows += "<tr>" + r + "</tr>";
});
$("<thead>" + cols + "</thead><tbody>" + rows + "</tobdy>").appendTo("#results");
}
function setCurrentTab(id) {
$("#nav ul li.selected").removeClass("selected");
$("#" + id).addClass("selected");
}
function showQueryHistory() {
getHistory(function(data) {
var rows = [];
for(i in data) {
rows.unshift([parseInt(i) + 1, data[i]]);
}
buildTable({ columns: ["id", "query"], rows: rows });
setCurrentTab("table_history");
$("#input").hide();
$("#output").addClass("full");
$("#results").addClass("no-crop");
2014-10-13 22:55:19 +04:00
});
}
function showTableIndexes() {
2014-12-02 05:51:20 +03:00
var name = getCurrentTable();
2014-10-13 22:55:19 +04:00
if (name.length == 0) {
alert("Please select a table!");
return;
}
getTableIndexes(name, function(data) {
setCurrentTab("table_indexes");
buildTable(data);
$("#input").hide();
$("#output").addClass("full");
$("#results").addClass("no-crop");
2014-10-13 22:55:19 +04:00
});
}
2014-10-18 07:33:33 +04:00
function showTableInfo() {
2014-12-02 05:51:20 +03:00
var name = getCurrentTable();
2014-10-18 07:33:33 +04:00
if (name.length == 0) {
alert("Please select a table!");
return;
}
apiCall("get", "/tables/" + name + "/info", {}, function(data) {
$(".table-information ul").show();
$("#table_total_size").text(data.total_size);
$("#table_data_size").text(data.data_size);
$("#table_index_size").text(data.index_size);
$("#table_rows_count").text(data.rows_count);
$("#table_encoding").text("Unknown");
2014-10-18 07:33:33 +04:00
});
}
2014-10-13 22:55:19 +04:00
function showTableContent() {
2014-12-02 05:51:20 +03:00
var name = getCurrentTable();
2014-10-13 22:55:19 +04:00
if (name.length == 0) {
alert("Please select a table!");
return;
}
var query = "SELECT * FROM \"" + name + "\" LIMIT 100;";
2014-10-13 22:55:19 +04:00
executeQuery(query, function(data) {
buildTable(data);
setCurrentTab("table_content");
$("#results").attr("data-mode", "browse");
2014-10-13 22:55:19 +04:00
$("#input").hide();
$("#output").addClass("full");
});
}
function showTableStructure() {
2014-12-02 05:51:20 +03:00
var name = getCurrentTable();
2014-10-13 22:55:19 +04:00
if (name.length == 0) {
alert("Please select a table!");
return;
}
getTableStructure(name, function(data) {
setCurrentTab("table_structure");
buildTable(data);
});
}
function showQueryPanel() {
setCurrentTab("table_query");
editor.focus();
$("#input").show();
$("#output").removeClass("full");
}
function showConnectionPanel() {
setCurrentTab("table_connection");
apiCall("get", "/info", {}, function(data) {
var rows = [];
for(key in data) {
rows.push([key, data[key]]);
}
buildTable({
columns: ["attribute", "value"],
rows: rows
});
$("#input").hide();
$("#output").addClass("full");
});
}
2014-10-13 22:55:19 +04:00
function runQuery() {
setCurrentTab("table_query");
$("#run, #explain, #csv").prop("disabled", true);
$("#query_progress").show();
2014-10-15 06:32:46 +04:00
var query = $.trim(editor.getValue());
if (query.length == 0) {
$("#run, #explain, #csv").prop("disabled", false);
$("#query_progress").hide();
2014-10-15 06:32:46 +04:00
return;
}
executeQuery(query, function(data) {
2014-10-13 22:55:19 +04:00
buildTable(data);
$("#run, #explain, #csv").prop("disabled", false);
2014-10-15 06:32:46 +04:00
$("#query_progress").hide();
$("#input").show();
$("#output").removeClass("full");
if (query.toLowerCase().indexOf("explain") != -1) {
$("#results").addClass("no-crop");
}
var re = /(create|drop) table/i;
// Refresh tables list if table was added or removed
if (query.match(re)) {
loadTables();
}
2014-10-15 06:32:46 +04:00
});
}
function runExplain() {
setCurrentTab("table_query");
$("#run, #explain, #csv").prop("disabled", true);
2014-10-15 06:32:46 +04:00
$("#query_progress").show();
var query = $.trim(editor.getValue());
if (query.length == 0) {
$("#run, #explain, #csv").prop("disabled", false);
$("#query_progress").hide();
2014-10-15 06:32:46 +04:00
return;
}
explainQuery(query, function(data) {
2014-10-15 06:32:46 +04:00
buildTable(data);
$("#run, #explain, #csv").prop("disabled", false);
$("#query_progress").hide();
2014-10-13 22:55:19 +04:00
$("#input").show();
$("#output").removeClass("full");
$("#results").addClass("no-crop");
2014-10-13 22:55:19 +04:00
});
}
2014-10-18 19:07:19 +04:00
function exportToCSV() {
var query = $.trim(editor.getValue());
if (query.length == 0) {
return;
}
2014-10-30 02:35:13 +03:00
// Replace line breaks with spaces and properly encode query
query = window.encodeURI(query.replace(/\n/g, " "));
var url = "http://" + window.location.host + "/query?format=csv&query=" + query;
var win = window.open(url, '_blank');
2014-10-30 02:35:13 +03:00
setCurrentTab("table_query");
win.focus();
2014-10-18 19:07:19 +04:00
}
function initEditor() {
2014-10-13 22:55:19 +04:00
editor = ace.edit("custom_query");
2014-10-13 22:55:19 +04:00
editor.getSession().setMode("ace/mode/pgsql");
editor.getSession().setTabSize(2);
editor.getSession().setUseSoftTabs(true);
2014-10-30 08:12:05 +03:00
editor.commands.addCommands([{
name: "run_query",
bindKey: {
win: "Ctrl-Enter",
mac: "Command-Enter"
},
exec: function(editor) {
runQuery();
}
2014-10-30 08:12:05 +03:00
}, {
name: "explain_query",
bindKey: {
win: "Ctrl-E",
mac: "Command-E"
},
exec: function(editor) {
runExplain();
}
}]);
}
function addShortcutTooltips() {
if (navigator.userAgent.indexOf("OS X") > 0) {
$("#run").attr("title", "Shortcut: ⌘+Enter");
$("#explain").attr("title", "Shortcut: ⌘+E");
}
else {
$("#run").attr("title", "Shortcut: Ctrl+Enter");
$("#explain").attr("title", "Shortcut: Ctrl+E");
}
}
2014-11-02 04:06:15 +03:00
function showConnectionSettings() {
$("#connection_window").show();
}
function getConnectionString() {
var url = $.trim($("#connection_url").val());
var mode = $(".connection-group-switch button.active").attr("data");
var ssl = $("#connection_ssl").val();
if (mode == "standard") {
var host = $("#pg_host").val();
var port = $("#pg_port").val();
var user = $("#pg_user").val();
var pass = $("#pg_password").val();
var db = $("#pg_db").val();
if (port.length == 0) {
port = "5432";
}
url = "postgres://" + user + ":" + pass + "@" + host + ":" + port + "/" + db + "?sslmode=" + ssl;
}
else {
var local = url.indexOf("localhost") != -1 || url.indexOf("127.0.0.1") != -1;
if (local && url.indexOf("sslmode") == -1) {
url += "?sslmode=" + ssl;
}
}
return url;
}
$(document).ready(function() {
$("#table_content").on("click", function() { showTableContent(); });
$("#table_structure").on("click", function() { showTableStructure(); });
$("#table_indexes").on("click", function() { showTableIndexes(); });
$("#table_history").on("click", function() { showQueryHistory(); });
$("#table_query").on("click", function() { showQueryPanel(); });
$("#table_connection").on("click", function() { showConnectionPanel(); });
2014-10-13 22:55:19 +04:00
$("#run").on("click", function() {
runQuery();
});
2014-10-15 06:32:46 +04:00
$("#explain").on("click", function() {
runExplain();
});
2014-10-18 19:07:19 +04:00
$("#csv").on("click", function() {
exportToCSV();
});
2014-10-13 22:55:19 +04:00
$("#results").on("click", "tr", function() {
$("#results tr.selected").removeClass();
$(this).addClass("selected");
});
$("#results").on("dblclick", "td > div", function() {
if ($(this).has("textarea").length > 0) {
return;
}
var value = unescapeHtml($(this).html());
if (!value) { return; }
var textarea = $("<textarea />").
text(value).
addClass("form-control").
css("width", $(this).css("width"));
if (value.split("\n").length >= 3) {
textarea.css("height", "200px");
}
$(this).html(textarea).css("max-height", "200px");
});
2014-10-13 22:55:19 +04:00
$("#tables").on("click", "li", function() {
$("#tables li.selected").removeClass("selected");
$(this).addClass("selected");
2014-12-02 05:51:20 +03:00
$("#tables").attr("data-current", $.trim($(this).text()));
2014-10-13 22:55:19 +04:00
showTableContent();
showTableInfo();
2014-10-13 22:55:19 +04:00
});
2014-11-02 04:06:15 +03:00
$("#edit_connection").on("click", function() {
if (connected) {
$("#close_connection_window").show();
}
showConnectionSettings();
});
$("#close_connection_window").on("click", function() {
$("#connection_window").hide();
});
$("#connection_url").on("change", function() {
if ($(this).val().indexOf("localhost") != -1) {
$("#connection_ssl").val("disable");
}
});
$("#pg_host").on("change", function() {
var value = $(this).val();
if (value.indexOf("localhost") != -1 || value.indexOf("127.0.0.1") != -1) {
$("#connection_ssl").val("disable");
}
});
2014-11-02 04:06:15 +03:00
2014-11-07 01:05:49 +03:00
$(".connection-group-switch button").on("click", function() {
$(".connection-group-switch button").removeClass("active");
$(this).addClass("active");
switch($(this).attr("data")) {
case "scheme":
$(".connection-scheme-group").show();
$(".connection-standard-group").hide();
return;
case "standard":
$(".connection-scheme-group").hide();
$(".connection-standard-group").show();
$(".connection-ssh-group").hide();
return;
case "ssh":
$(".connection-scheme-group").hide();
$(".connection-standard-group").show();
$(".connection-ssh-group").show();
return;
}
});
$("#connection_form").on("submit", function(e) {
e.preventDefault();
var button = $(this).children("button");
var url = getConnectionString();
if (url.length == 0) {
return;
}
$("#connection_error").hide();
button.prop("disabled", true).text("Please wait...");
apiCall("post", "/connect", { url: url }, function(resp) {
button.prop("disabled", false).text("Connect");
if (resp.error) {
2014-11-02 04:06:15 +03:00
connected = false;
$("#connection_error").text(resp.error).show();
}
else {
2014-11-02 04:06:15 +03:00
connected = true;
$("#connection_window").hide();
loadTables();
$("#main").show();
}
});
});
initEditor();
addShortcutTooltips();
apiCall("get", "/info", {}, function(resp) {
if (resp.error) {
2014-11-02 04:06:15 +03:00
connected = false;
showConnectionSettings();
}
else {
2014-11-02 04:06:15 +03:00
connected = true;
loadTables();
$("#main").show();
}
});
2014-10-13 22:55:19 +04:00
});