Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
Browse files

Homepage customization

  • Loading branch information...
commit 74161649669ba0378cdd6e927b0916d228db74e8 1 parent d7a3e41
@vrana authored
View
221 adminer/db.inc.php
@@ -32,129 +32,128 @@
}
page_header(($_GET["ns"] == "" ? lang('Database') . ": " . h(DB) : lang('Schema') . ": " . h($_GET["ns"])), $error, true);
-echo '<p>' . ($_GET["ns"] == "" ? '<a href="' . h(ME) . 'database=">' . lang('Alter database') . "</a>\n" : "");
-if (support("scheme")) {
- echo "<a href='" . h(ME) . "scheme='>" . ($_GET["ns"] != "" ? lang('Alter schema') : lang('Create schema')) . "</a>\n";
-}
-if ($_GET["ns"] !== "") {
- echo '<a href="' . h(ME) . 'schema=">' . lang('Database schema') . "</a>\n";
- echo "<h3>" . lang('Tables and views') . "</h3>\n";
- $tables_list = tables_list();
- if (!$tables_list) {
- echo "<p class='message'>" . lang('No tables.') . "\n";
- } else {
- echo "<form action='' method='post'>\n";
- echo "<p>" . lang('Search data in tables') . ": <input name='query' value='" . h($_POST["query"]) . "'> <input type='submit' name='search' value='" . lang('Search') . "'>\n";
- if ($_POST["search"] && $_POST["query"] != "") {
- search_tables();
- }
- echo "<table cellspacing='0' class='nowrap' onclick='tableClick(event);'>\n";
- echo '<thead><tr class="wrap"><td><input id="check-all" type="checkbox" onclick="formCheck(this, /^(tables|views)\[/);"><th>' . lang('Table') . '<td>' . lang('Engine') . '<td>' . lang('Collation') . '<td>' . lang('Data Length') . '<td>' . lang('Index Length') . '<td>' . lang('Data Free') . '<td>' . lang('Auto Increment') . '<td>' . lang('Rows') . (support("comment") ? '<td>' . lang('Comment') : '') . "</thead>\n";
- foreach ($tables_list as $name => $type) {
- $view = (isset($type) && !eregi("table", $type));
- echo '<tr' . odd() . '><td>' . checkbox(($view ? "views[]" : "tables[]"), $name, in_array($name, $tables_views, true), "", "formUncheck('check-all');");
- echo '<th><a href="' . h(ME) . 'table=' . urlencode($name) . '">' . h($name) . '</a>';
- if ($view) {
- echo '<td colspan="6"><a href="' . h(ME) . "view=" . urlencode($name) . '">' . lang('View') . '</a>';
- echo '<td align="right"><a href="' . h(ME) . "select=" . urlencode($name) . '">?</a>';
- } else {
- echo "<td id='Engine-" . h($name) . "'>&nbsp;<td id='Collation-" . h($name) . "'>&nbsp;";
- foreach (array("Data_length" => "create", "Index_length" => "indexes", "Data_free" => "edit", "Auto_increment" => "auto_increment=1&create", "Rows" => "select") as $key => $link) {
- echo "<td align='right'><a href='" . h(ME . "$link=") . urlencode($name) . "' id='$key-" . h($name) . "'>?</a>";
+
+if ($adminer->homepage()) {
+ if ($_GET["ns"] !== "") {
+ echo '<a href="' . h(ME) . 'schema=">' . lang('Database schema') . "</a>\n";
+ echo "<h3>" . lang('Tables and views') . "</h3>\n";
+ $tables_list = tables_list();
+ if (!$tables_list) {
+ echo "<p class='message'>" . lang('No tables.') . "\n";
+ } else {
+ echo "<form action='' method='post'>\n";
+ echo "<p>" . lang('Search data in tables') . ": <input name='query' value='" . h($_POST["query"]) . "'> <input type='submit' name='search' value='" . lang('Search') . "'>\n";
+ if ($_POST["search"] && $_POST["query"] != "") {
+ search_tables();
+ }
+ echo "<table cellspacing='0' class='nowrap' onclick='tableClick(event);'>\n";
+ echo '<thead><tr class="wrap"><td><input id="check-all" type="checkbox" onclick="formCheck(this, /^(tables|views)\[/);"><th>' . lang('Table') . '<td>' . lang('Engine') . '<td>' . lang('Collation') . '<td>' . lang('Data Length') . '<td>' . lang('Index Length') . '<td>' . lang('Data Free') . '<td>' . lang('Auto Increment') . '<td>' . lang('Rows') . (support("comment") ? '<td>' . lang('Comment') : '') . "</thead>\n";
+ foreach ($tables_list as $name => $type) {
+ $view = (isset($type) && !eregi("table", $type));
+ echo '<tr' . odd() . '><td>' . checkbox(($view ? "views[]" : "tables[]"), $name, in_array($name, $tables_views, true), "", "formUncheck('check-all');");
+ echo '<th><a href="' . h(ME) . 'table=' . urlencode($name) . '">' . h($name) . '</a>';
+ if ($view) {
+ echo '<td colspan="6"><a href="' . h(ME) . "view=" . urlencode($name) . '">' . lang('View') . '</a>';
+ echo '<td align="right"><a href="' . h(ME) . "select=" . urlencode($name) . '">?</a>';
+ } else {
+ echo "<td id='Engine-" . h($name) . "'>&nbsp;<td id='Collation-" . h($name) . "'>&nbsp;";
+ foreach (array("Data_length" => "create", "Index_length" => "indexes", "Data_free" => "edit", "Auto_increment" => "auto_increment=1&create", "Rows" => "select") as $key => $link) {
+ echo "<td align='right'><a href='" . h(ME . "$link=") . urlencode($name) . "' id='$key-" . h($name) . "'>?</a>";
+ }
}
+ echo (support("comment") ? "<td id='Comment-" . h($name) . "'>&nbsp;" : "");
}
- echo (support("comment") ? "<td id='Comment-" . h($name) . "'>&nbsp;" : "");
- }
- echo "<tr><td>&nbsp;<th>" . lang('%d in total', count($tables_list));
- echo "<td>" . nbsp($connection->result("SELECT @@storage_engine"));
- echo "<td>" . nbsp(db_collation(DB, collations()));
- foreach (array("Data_length", "Index_length", "Data_free") as $key) {
- echo "<td align='right' id='sum-$key'>&nbsp;";
- }
- echo "</table>\n";
- if (!information_schema(DB)) {
- echo "<p><input type='hidden' name='token' value='$token'>" . ($jush == "sql" ? "<input type='submit' value='" . lang('Analyze') . "'> <input type='submit' name='optimize' value='" . lang('Optimize') . "'> <input type='submit' name='check' value='" . lang('Check') . "'> <input type='submit' name='repair' value='" . lang('Repair') . "'> " : "") . "<input type='submit' name='truncate' value='" . lang('Truncate') . "'" . confirm("formChecked(this, /tables/)") . "> <input type='submit' name='drop' value='" . lang('Drop') . "'" . confirm("formChecked(this, /tables|views/)", 1) . ">\n"; // 1 - eventStop
- $databases = (support("scheme") ? schemas() : get_databases());
- if (count($databases) != 1 && $jush != "sqlite") {
- $db = (isset($_POST["target"]) ? $_POST["target"] : (support("scheme") ? $_GET["ns"] : DB));
- echo "<p>" . lang('Move to other database') . ($databases ? ": " . html_select("target", $databases, $db) : ': <input name="target" value="' . h($db) . '">') . " <input type='submit' name='move' value='" . lang('Move') . "' onclick='eventStop(event);'>\n";
+ echo "<tr><td>&nbsp;<th>" . lang('%d in total', count($tables_list));
+ echo "<td>" . nbsp($connection->result("SELECT @@storage_engine"));
+ echo "<td>" . nbsp(db_collation(DB, collations()));
+ foreach (array("Data_length", "Index_length", "Data_free") as $key) {
+ echo "<td align='right' id='sum-$key'>&nbsp;";
}
+ echo "</table>\n";
+ if (!information_schema(DB)) {
+ echo "<p><input type='hidden' name='token' value='$token'>" . ($jush == "sql" ? "<input type='submit' value='" . lang('Analyze') . "'> <input type='submit' name='optimize' value='" . lang('Optimize') . "'> <input type='submit' name='check' value='" . lang('Check') . "'> <input type='submit' name='repair' value='" . lang('Repair') . "'> " : "") . "<input type='submit' name='truncate' value='" . lang('Truncate') . "'" . confirm("formChecked(this, /tables/)") . "> <input type='submit' name='drop' value='" . lang('Drop') . "'" . confirm("formChecked(this, /tables|views/)", 1) . ">\n"; // 1 - eventStop
+ $databases = (support("scheme") ? schemas() : get_databases());
+ if (count($databases) != 1 && $jush != "sqlite") {
+ $db = (isset($_POST["target"]) ? $_POST["target"] : (support("scheme") ? $_GET["ns"] : DB));
+ echo "<p>" . lang('Move to other database') . ($databases ? ": " . html_select("target", $databases, $db) : ': <input name="target" value="' . h($db) . '">') . " <input type='submit' name='move' value='" . lang('Move') . "' onclick='eventStop(event);'>\n";
+ }
+ }
+ echo "</form>\n";
+ }
+
+ echo '<p><a href="' . h(ME) . 'create=">' . lang('Create table') . "</a>\n";
+ if (support("view")) {
+ echo '<a href="' . h(ME) . 'view=">' . lang('Create view') . "</a>\n";
}
- echo "</form>\n";
- }
- echo '<p><a href="' . h(ME) . 'create=">' . lang('Create table') . "</a>\n";
- if (support("view")) {
- echo '<a href="' . h(ME) . 'view=">' . lang('Create view') . "</a>\n";
- }
-
- if (support("routine")) {
- echo "<h3>" . lang('Routines') . "</h3>\n";
- $routines = routines();
- if ($routines) {
- echo "<table cellspacing='0'>\n";
- echo '<thead><tr><th>' . lang('Name') . '<td>' . lang('Type') . '<td>' . lang('Return type') . "<td>&nbsp;</thead>\n";
- odd('');
- foreach ($routines as $row) {
- echo '<tr' . odd() . '>';
- echo '<th><a href="' . h(ME) . ($row["ROUTINE_TYPE"] == "FUNCTION" ? 'callf=' : 'call=') . urlencode($row["ROUTINE_NAME"]) . '">' . h($row["ROUTINE_NAME"]) . '</a>';
- echo '<td>' . h($row["ROUTINE_TYPE"]);
- echo '<td>' . h($row["DTD_IDENTIFIER"]);
- echo '<td><a href="' . h(ME) . ($row["ROUTINE_TYPE"] == "FUNCTION" ? 'function=' : 'procedure=') . urlencode($row["ROUTINE_NAME"]) . '">' . lang('Alter') . "</a>";
+ if (support("routine")) {
+ echo "<h3>" . lang('Routines') . "</h3>\n";
+ $routines = routines();
+ if ($routines) {
+ echo "<table cellspacing='0'>\n";
+ echo '<thead><tr><th>' . lang('Name') . '<td>' . lang('Type') . '<td>' . lang('Return type') . "<td>&nbsp;</thead>\n";
+ odd('');
+ foreach ($routines as $row) {
+ echo '<tr' . odd() . '>';
+ echo '<th><a href="' . h(ME) . ($row["ROUTINE_TYPE"] == "FUNCTION" ? 'callf=' : 'call=') . urlencode($row["ROUTINE_NAME"]) . '">' . h($row["ROUTINE_NAME"]) . '</a>';
+ echo '<td>' . h($row["ROUTINE_TYPE"]);
+ echo '<td>' . h($row["DTD_IDENTIFIER"]);
+ echo '<td><a href="' . h(ME) . ($row["ROUTINE_TYPE"] == "FUNCTION" ? 'function=' : 'procedure=') . urlencode($row["ROUTINE_NAME"]) . '">' . lang('Alter') . "</a>";
+ }
+ echo "</table>\n";
}
- echo "</table>\n";
+ echo '<p><a href="' . h(ME) . 'procedure=">' . lang('Create procedure') . '</a> <a href="' . h(ME) . 'function=">' . lang('Create function') . "</a>\n";
}
- echo '<p><a href="' . h(ME) . 'procedure=">' . lang('Create procedure') . '</a> <a href="' . h(ME) . 'function=">' . lang('Create function') . "</a>\n";
- }
-
- if (support("sequence")) {
- echo "<h3>" . lang('Sequences') . "</h3>\n";
- $sequences = get_vals("SELECT sequence_name FROM information_schema.sequences WHERE sequence_schema = current_schema()");
- if ($sequences) {
- echo "<table cellspacing='0'>\n";
- echo "<thead><tr><th>" . lang('Name') . "</thead>\n";
- odd('');
- foreach ($sequences as $val) {
- echo "<tr" . odd() . "><th><a href='" . h(ME) . "sequence=" . urlencode($val) . "'>" . h($val) . "</a>\n";
+
+ if (support("sequence")) {
+ echo "<h3>" . lang('Sequences') . "</h3>\n";
+ $sequences = get_vals("SELECT sequence_name FROM information_schema.sequences WHERE sequence_schema = current_schema()");
+ if ($sequences) {
+ echo "<table cellspacing='0'>\n";
+ echo "<thead><tr><th>" . lang('Name') . "</thead>\n";
+ odd('');
+ foreach ($sequences as $val) {
+ echo "<tr" . odd() . "><th><a href='" . h(ME) . "sequence=" . urlencode($val) . "'>" . h($val) . "</a>\n";
+ }
+ echo "</table>\n";
}
- echo "</table>\n";
+ echo "<p><a href='" . h(ME) . "sequence='>" . lang('Create sequence') . "</a>\n";
}
- echo "<p><a href='" . h(ME) . "sequence='>" . lang('Create sequence') . "</a>\n";
- }
-
- if (support("type")) {
- echo "<h3>" . lang('User types') . "</h3>\n";
- $types = types();
- if ($types) {
- echo "<table cellspacing='0'>\n";
- echo "<thead><tr><th>" . lang('Name') . "</thead>\n";
- odd('');
- foreach ($types as $val) {
- echo "<tr" . odd() . "><th><a href='" . h(ME) . "type=" . urlencode($val) . "'>" . h($val) . "</a>\n";
+
+ if (support("type")) {
+ echo "<h3>" . lang('User types') . "</h3>\n";
+ $types = types();
+ if ($types) {
+ echo "<table cellspacing='0'>\n";
+ echo "<thead><tr><th>" . lang('Name') . "</thead>\n";
+ odd('');
+ foreach ($types as $val) {
+ echo "<tr" . odd() . "><th><a href='" . h(ME) . "type=" . urlencode($val) . "'>" . h($val) . "</a>\n";
+ }
+ echo "</table>\n";
}
- echo "</table>\n";
+ echo "<p><a href='" . h(ME) . "type='>" . lang('Create type') . "</a>\n";
}
- echo "<p><a href='" . h(ME) . "type='>" . lang('Create type') . "</a>\n";
- }
-
- if (support("event")) {
- echo "<h3>" . lang('Events') . "</h3>\n";
- $rows = get_rows("SHOW EVENTS");
- if ($rows) {
- echo "<table cellspacing='0'>\n";
- echo "<thead><tr><th>" . lang('Name') . "<td>" . lang('Schedule') . "<td>" . lang('Start') . "<td>" . lang('End') . "</thead>\n";
- foreach ($rows as $row) {
- echo "<tr>";
- echo '<th><a href="' . h(ME) . 'event=' . urlencode($row["Name"]) . '">' . h($row["Name"]) . "</a>";
- echo "<td>" . ($row["Execute at"] ? lang('At given time') . "<td>" . $row["Execute at"] : lang('Every') . " " . $row["Interval value"] . " " . $row["Interval field"] . "<td>$row[Starts]");
- echo "<td>$row[Ends]";
+
+ if (support("event")) {
+ echo "<h3>" . lang('Events') . "</h3>\n";
+ $rows = get_rows("SHOW EVENTS");
+ if ($rows) {
+ echo "<table cellspacing='0'>\n";
+ echo "<thead><tr><th>" . lang('Name') . "<td>" . lang('Schedule') . "<td>" . lang('Start') . "<td>" . lang('End') . "</thead>\n";
+ foreach ($rows as $row) {
+ echo "<tr>";
+ echo '<th><a href="' . h(ME) . 'event=' . urlencode($row["Name"]) . '">' . h($row["Name"]) . "</a>";
+ echo "<td>" . ($row["Execute at"] ? lang('At given time') . "<td>" . $row["Execute at"] : lang('Every') . " " . $row["Interval value"] . " " . $row["Interval field"] . "<td>$row[Starts]");
+ echo "<td>$row[Ends]";
+ }
+ echo "</table>\n";
}
- echo "</table>\n";
+ echo '<p><a href="' . h(ME) . 'event=">' . lang('Create event') . "</a>\n";
+ }
+
+ if ($tables_list) {
+ echo "<script type='text/javascript'>ajaxSetHtml('" . js_escape(ME) . "script=db');</script>\n";
}
- echo '<p><a href="' . h(ME) . 'event=">' . lang('Create event') . "</a>\n";
- }
-
- if ($tables_list) {
- echo "<script type='text/javascript'>ajaxSetHtml('" . js_escape(ME) . "script=db');</script>\n";
}
}
View
11 adminer/include/adminer.inc.php
@@ -682,6 +682,17 @@ function dumpHeaders($identifier, $multi_table = false) {
return $ext;
}
+ /** Print homepage
+ * @return bool whether to print default homepage
+ */
+ function homepage() {
+ echo '<p>' . ($_GET["ns"] == "" ? '<a href="' . h(ME) . 'database=">' . lang('Alter database') . "</a>\n" : "");
+ if (support("scheme")) {
+ echo "<a href='" . h(ME) . "scheme='>" . ($_GET["ns"] != "" ? lang('Alter schema') : lang('Create schema')) . "</a>\n";
+ }
+ return true;
+ }
+
/** Prints navigation after Adminer title
* @param string can be "auth" if there is no database connection, "db" if there is no database selected, "ns" with invalid schema
* @return null
View
1  changes.txt
@@ -7,6 +7,7 @@ History: edit all
MS SQL: auto primary and foreign key
SQLite: display 0
Create table default data type: int
+Homepage customization
Work without session.use_cookies (bug #3138640)
Portuguese translation
View
34 editor/db.inc.php
@@ -1,21 +1,23 @@
<?php
page_header(lang('Server'), "", false);
-echo "<form action='' method='post'>\n";
-echo "<p>" . lang('Search data in tables') . ": <input name='query' value='" . h($_POST["query"]) . "'> <input type='submit' value='" . lang('Search') . "'>\n";
-if ($_POST["query"] != "") {
- search_tables();
-}
-echo "<table cellspacing='0' class='nowrap' onclick='tableClick(event);'>\n";
-echo '<thead><tr class="wrap"><td><input id="check-all" type="checkbox" onclick="formCheck(this, /^tables\[/);"><th>' . lang('Table') . '<td>' . lang('Rows') . "</thead>\n";
-foreach (table_status() as $table => $row) {
- $name = $adminer->tableName($row);
- if (isset($row["Engine"]) && $name != "") {
- echo '<tr' . odd() . '><td>' . checkbox("tables[]", $table, in_array($table, (array) $_POST["tables"], true), "", "formUncheck('check-all');");
- echo '<th><a href="' . h(ME) . 'select=' . urlencode($table) . '">' . h($name) . '</a>';
- $val = number_format($row["Rows"], 0, '.', lang(','));
- echo "<td align='right'><a href='" . h(ME . "edit=") . urlencode($table) . "'>" . ($row["Engine"] == "InnoDB" && $val ? "~ $val" : $val) . "</a>";
+if ($adminer->homepage()) {
+ echo "<form action='' method='post'>\n";
+ echo "<p>" . lang('Search data in tables') . ": <input name='query' value='" . h($_POST["query"]) . "'> <input type='submit' value='" . lang('Search') . "'>\n";
+ if ($_POST["query"] != "") {
+ search_tables();
+ }
+ echo "<table cellspacing='0' class='nowrap' onclick='tableClick(event);'>\n";
+ echo '<thead><tr class="wrap"><td><input id="check-all" type="checkbox" onclick="formCheck(this, /^tables\[/);"><th>' . lang('Table') . '<td>' . lang('Rows') . "</thead>\n";
+ foreach (table_status() as $table => $row) {
+ $name = $adminer->tableName($row);
+ if (isset($row["Engine"]) && $name != "") {
+ echo '<tr' . odd() . '><td>' . checkbox("tables[]", $table, in_array($table, (array) $_POST["tables"], true), "", "formUncheck('check-all');");
+ echo '<th><a href="' . h(ME) . 'select=' . urlencode($table) . '">' . h($name) . '</a>';
+ $val = number_format($row["Rows"], 0, '.', lang(','));
+ echo "<td align='right'><a href='" . h(ME . "edit=") . urlencode($table) . "'>" . ($row["Engine"] == "InnoDB" && $val ? "~ $val" : $val) . "</a>";
+ }
}
+ echo "</table>\n";
+ echo "</form>\n";
}
-echo "</table>\n";
-echo "</form>\n";
View
4 editor/include/adminer.inc.php
@@ -465,6 +465,10 @@ function dumpHeaders($identifier) {
return $ext;
}
+ function homepage() {
+ return true;
+ }
+
function navigation($missing) {
global $VERSION, $token;
?>
Please sign in to comment.
Something went wrong with that request. Please try again.