adminerevo/adminer/include/design.inc.php

128 lines
4.7 KiB
PHP
Raw Normal View History

<?php
/** Print HTML header
2011-03-23 20:05:04 +00:00
* @param string used in title, breadcrumb and heading, should be HTML escaped
* @param string
* @param mixed array("key" => "link", "key2" => array("link", "desc")), null for nothing, false for driver only, true for driver and server
* @param string used after colon in title and heading, should be HTML escaped
* @return null
*/
function page_header($title, $error = "", $breadcrumb = array(), $title2 = "") {
global $LANG, $adminer, $connection, $drivers, $jush;
2013-06-29 19:41:35 +00:00
page_headers();
$title_all = $title . ($title2 != "" ? ": $title2" : "");
2011-03-23 20:05:04 +00:00
$title_page = strip_tags($title_all . (SERVER != "" && SERVER != "localhost" ? h(" - " . SERVER) : "") . " - " . $adminer->name());
2012-04-16 05:18:03 +00:00
?>
2012-12-05 21:11:36 +00:00
<!DOCTYPE html>
2010-11-11 09:12:26 +00:00
<html lang="<?php echo $LANG; ?>" dir="<?php echo lang('ltr'); ?>">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="Content-Script-Type" content="text/javascript">
<meta name="robots" content="noindex">
2010-11-22 17:13:07 +00:00
<title><?php echo $title_page; ?></title>
2011-02-09 14:28:45 +00:00
<link rel="stylesheet" type="text/css" href="../adminer/static/default.css">
<script type="text/javascript" src="../adminer/static/functions.js"></script>
<script type="text/javascript" src="static/editing.js"></script>
2011-04-03 15:17:26 +00:00
<?php if ($adminer->head()) { ?>
2013-02-20 00:31:51 +00:00
<link rel="shortcut icon" type="image/x-icon" href="../adminer/static/favicon.ico">
<link rel="apple-touch-icon" href="../adminer/static/favicon.ico">
2011-04-03 15:17:26 +00:00
<?php if (file_exists("adminer.css")) { ?>
<link rel="stylesheet" type="text/css" href="adminer.css">
<?php } ?>
2011-04-03 15:17:26 +00:00
<?php } ?>
<body class="<?php echo lang('ltr'); ?> nojs" onkeydown="bodyKeydown(event);" onclick="bodyClick(event);" onload="bodyLoad('<?php echo (is_object($connection) ? substr($connection->server_info, 0, 3) : ""); ?>');<?php echo (isset($_COOKIE["adminer_version"]) ? "" : " verifyVersion();"); ?>">
<script type="text/javascript">
document.body.className = document.body.className.replace(/ nojs/, ' js');
</script>
2013-07-19 20:04:14 +00:00
<div id="help" class="jush-<?php echo $jush; ?> jsonly hidden" onmouseover="helpOpen = 1;" onmouseout="helpMouseout(this, event);"></div>
<div id="content">
<?php
2012-05-14 06:54:07 +00:00
if ($breadcrumb !== null) {
2013-07-03 17:34:19 +00:00
$link = substr(preg_replace('~\b(username|db|ns)=[^&]*&~', '', ME), 0, -1);
echo '<p id="breadcrumb"><a href="' . h($link ? $link : ".") . '">' . $drivers[DRIVER] . '</a> &raquo; ';
2013-07-03 17:34:19 +00:00
$link = substr(preg_replace('~\b(db|ns)=[^&]*&~', '', ME), 0, -1);
2010-11-18 11:17:06 +00:00
$server = (SERVER != "" ? h(SERVER) : lang('Server'));
if ($breadcrumb === false) {
echo "$server\n";
} else {
echo "<a href='" . ($link ? h($link) : ".") . "' accesskey='1' title='Alt+Shift+1'>$server</a> &raquo; ";
2010-11-18 11:17:06 +00:00
if ($_GET["ns"] != "" || (DB != "" && is_array($breadcrumb))) {
echo '<a href="' . h($link . "&db=" . urlencode(DB) . (support("scheme") ? "&ns=" : "")) . '">' . h(DB) . '</a> &raquo; ';
}
if (is_array($breadcrumb)) {
if ($_GET["ns"] != "") {
echo '<a href="' . h(substr(ME, 0, -1)) . '">' . h($_GET["ns"]) . '</a> &raquo; ';
}
2010-11-18 11:17:06 +00:00
foreach ($breadcrumb as $key => $val) {
2013-07-05 04:07:52 +00:00
$desc = (is_array($val) ? $val[1] : h($val));
2010-11-18 11:17:06 +00:00
if ($desc != "") {
2013-07-05 04:07:52 +00:00
echo "<a href='" . h(ME . "$key=") . urlencode(is_array($val) ? $val[0] : $val) . "'>$desc</a> &raquo; ";
}
}
}
2010-11-18 11:17:06 +00:00
echo "$title\n";
}
}
2010-11-18 11:17:06 +00:00
echo "<h2>$title_all</h2>\n";
restart_session();
2013-06-29 19:41:35 +00:00
page_messages($error);
$databases = &get_session("dbs");
if (DB != "" && $databases && !in_array(DB, $databases, true)) {
$databases = null;
}
stop_session();
define("PAGE_HEADER", 1);
}
/** Send HTTP headers
* @return null
*/
function page_headers() {
global $adminer;
header("Content-Type: text/html; charset=utf-8");
if ($adminer->headers()) {
header("X-Frame-Options: deny"); // ClickJacking protection in IE8, Safari 4, Chrome 2, Firefox 3.6.9
header("X-XSS-Protection: 0"); // prevents introducing XSS in IE8 by removing safe parts of the page
}
}
/** Print flash and error messages
* @param string
* @return null
*/
function page_messages($error) {
2011-02-03 09:15:52 +00:00
$uri = preg_replace('~^[^?]*~', '', $_SERVER["REQUEST_URI"]);
$messages = $_SESSION["messages"][$uri];
if ($messages) {
echo "<div class='message'>" . implode("</div>\n<div class='message'>", $messages) . "</div>\n";
unset($_SESSION["messages"][$uri]);
}
if ($error) {
echo "<div class='error'>$error</div>\n";
}
}
/** Print HTML footer
2010-10-18 00:15:58 +00:00
* @param string "auth", "db", "ns"
* @return null
*/
function page_footer($missing = "") {
2013-07-09 06:34:17 +00:00
global $adminer, $token;
2012-04-16 05:18:03 +00:00
?>
2010-10-16 23:51:56 +00:00
</div>
<?php switch_lang(); ?>
2013-07-09 06:34:17 +00:00
<form action="" method="post">
<p class="logout">
<input type="submit" name="logout" value="<?php echo lang('Logout'); ?>" id="logout">
<input type="hidden" name="token" value="<?php echo $token; ?>">
</p>
</form>
<div id="menu">
<?php $adminer->navigation($missing); ?>
</div>
2013-05-05 00:02:59 +00:00
<script type="text/javascript">setupSubmitHighlight(document);</script>
<?php
}