mirror of
https://github.com/e107inc/e107.git
synced 2025-01-18 21:18:04 +01:00
468 lines
15 KiB
PHP
468 lines
15 KiB
PHP
<?php
|
|
/*
|
|
+---------------------------------------------------------------+
|
|
| e107 website system
|
|
| /e107_admin/header.php
|
|
|
|
|
| ©Steve Dunstan 2001-2002
|
|
| http://e107.org
|
|
| jalist@e107.org
|
|
|
|
|
| Released under the terms and conditions of the
|
|
| GNU General Public License (http://gnu.org).
|
|
|
|
|
| $Source: /cvs_backup/e107_0.8/e107_admin/header.php,v $
|
|
| $Revision: 1.15 $
|
|
| $Date: 2008-05-23 21:14:38 $
|
|
| $Author: e107steved $
|
|
+---------------------------------------------------------------+
|
|
*/
|
|
|
|
if (!defined('e107_INIT')) { exit; }
|
|
define("ADMIN_AREA",TRUE);
|
|
define("USER_AREA",FALSE);
|
|
$sql->db_Mark_Time('(Header Top)');
|
|
|
|
//
|
|
// *** Code sequence for headers ***
|
|
// IMPORTANT: These items are in a carefully constructed order. DO NOT REARRANGE
|
|
// without checking with experienced devs! Various subtle things WILL break.
|
|
//
|
|
// We realize this is a bit (!) of a mess and hope to make further cleanups in a future release.
|
|
//
|
|
// A: Admin Defines and Links
|
|
// B: Send HTTP headers that come before any html
|
|
// C: Send start of HTML
|
|
// D: Send JS
|
|
// E: Send CSS
|
|
// F: Send Meta Tags and Icon links
|
|
// G: Send final theme headers (theme_head() function)
|
|
// H: Generate JS for image preloading (setup for onload)
|
|
// I: Calculate onload() JS functions to be called
|
|
// J: Send end of html <head> and start of <body>
|
|
// K: (The rest is ignored for popups, which have no menus)
|
|
// L: (optional) Body JS to disable right clicks
|
|
// M: Send top of body for custom pages and for news
|
|
// N: Send other top-of-body HTML
|
|
//
|
|
// Load order notes for devs
|
|
// * Browsers wait until ALL HTML has loaded before executing ANY JS
|
|
// * The last CSS tag downloaded supercedes earlier CSS tags
|
|
// * Browsers don't care when Meta tags are loaded. We load last due to
|
|
// a quirk of e107's log subsystem.
|
|
// * Multiple external <link> file references slow down page load. Each one requires
|
|
// browser-server interaction even when cached.
|
|
//
|
|
|
|
//
|
|
// A: Admin Defines and Links
|
|
//
|
|
require_once(e_ADMIN.'ad_links.php');
|
|
if (isset($pref['del_unv']) && $pref['del_unv'] && $pref['user_reg_veri'] != 2)
|
|
{
|
|
$threshold=(time() - ($pref['del_unv'] * 60));
|
|
$sql->db_Delete("user", "user_ban = 2 AND user_join < '{$threshold}' ");
|
|
}
|
|
|
|
//
|
|
// B: Send HTTP headers (these come before ANY html)
|
|
//
|
|
|
|
// send the charset to the browser - overrides spurious server settings with the lan pack settings.
|
|
header("Content-type: text/html; charset=".CHARSET, true);
|
|
|
|
|
|
echo (defined("STANDARDS_MODE") ? "" : "<?xml version='1.0' encoding='".CHARSET."' "."?".">\n")."<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.1//EN\" \"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd\">\n";
|
|
|
|
//
|
|
// B.2: Include admin LAN defines
|
|
//
|
|
|
|
if (file_exists(e_LANGUAGEDIR.e_LANGUAGE.'/admin/lan_header.php')) {
|
|
@include_once(e_LANGUAGEDIR.e_LANGUAGE."/admin/lan_header.php");
|
|
} else {
|
|
@include_once(e_LANGUAGEDIR."English/admin/lan_header.php");
|
|
}
|
|
if (file_exists(e_LANGUAGEDIR.e_LANGUAGE.'/admin/lan_footer.php')) {
|
|
@include_once(e_LANGUAGEDIR.e_LANGUAGE.'/admin/lan_footer.php');
|
|
} else {
|
|
@include_once(e_LANGUAGEDIR.'English/admin/lan_footer.php');
|
|
}
|
|
if (!defined('ADMIN_WIDTH')) {
|
|
define('ADMIN_WIDTH', 'width: 95%');
|
|
}
|
|
|
|
if (!defined('ADMIN_TRUE_ICON'))
|
|
{
|
|
define("ADMIN_TRUE_ICON", "<img src='".e_IMAGE_ABS."packs/".$imode."/fileinspector/integrity_pass.png' alt='' style='border:0px; height:16px; width:16px' />");
|
|
define("ADMIN_TRUE_ICON_PATH", e_IMAGE."packs/".$imode."/fileinspector/integrity_pass.png");
|
|
}
|
|
|
|
if (!defined('ADMIN_FALSE_ICON'))
|
|
{
|
|
define("ADMIN_FALSE_ICON", "<img src='".e_IMAGE_ABS."packs/".$imode."/fileinspector/integrity_fail.png' alt='' style='border:0px; height:16px; width:16px' />");
|
|
define("ADMIN_FALSE_ICON_PATH", e_IMAGE."packs/".$imode."/fileinspector/integrity_fail.png");
|
|
}
|
|
|
|
|
|
if (!defined('ADMIN_EDIT_ICON'))
|
|
{
|
|
define("ADMIN_EDIT_ICON", "<img src='".e_IMAGE_ABS."packs/".$imode."/admin_images/edit_16.png' alt='' title='".LAN_EDIT."' style='border:0px; height:16px; width:16px' />");
|
|
define("ADMIN_EDIT_ICON_PATH", e_IMAGE."packs/".$imode."/admin_images/edit_16.png");
|
|
}
|
|
|
|
|
|
|
|
if (!defined('ADMIN_DELETE_ICON'))
|
|
{
|
|
define("ADMIN_DELETE_ICON", "<img src='".e_IMAGE_ABS."packs/".$imode."/admin_images/delete_16.png' alt='' title='".LAN_DELETE."' style='border:0px; height:16px; width:16px' />");
|
|
define("ADMIN_DELETE_ICON_PATH", e_IMAGE."packs/".$imode."/admin_images/delete_16.png");
|
|
}
|
|
|
|
//
|
|
// C: Send start of HTML
|
|
//
|
|
|
|
echo "<html xmlns='http://www.w3.org/1999/xhtml'".(defined("TEXTDIRECTION") ? " dir='".TEXTDIRECTION."'" : "").(defined("CORE_LC") ? " xml:lang=\"".CORE_LC."\"" : "").">
|
|
<head>
|
|
<title>".SITENAME." : ".LAN_head_4."</title>\n";
|
|
|
|
//
|
|
// D: Send JS
|
|
//
|
|
echo "<!-- *JS* -->\n";
|
|
|
|
// Wysiwyg JS support on or off.
|
|
// your code should run off e_WYSIWYG
|
|
if (varset($pref['wysiwyg'],FALSE) && check_class($pref['post_html']) && varset($e_wysiwyg) != "") {
|
|
define("e_WYSIWYG",TRUE);
|
|
}else{
|
|
define("e_WYSIWYG",FALSE);
|
|
}
|
|
|
|
if (strpos(e_SELF.'?'.e_QUERY, 'menus.php?configure') === FALSE) {
|
|
echo "<script type='text/javascript' src='".e_FILE_ABS."e_js.php'></script>\n";
|
|
echo "<script type='text/javascript' src='".e_FILE_ABS."e_ajax.php'></script>\n";
|
|
}
|
|
if (file_exists(THEME.'theme.js')) { echo "<script type='text/javascript' src='".THEME_ABS."theme.js'></script>\n"; }
|
|
if (is_readable(e_FILE.'user.js') && filesize(e_FILE.'user.js')) { echo "<script type='text/javascript' src='".e_FILE_ABS."user.js'></script>\n"; }
|
|
|
|
if (isset($eplug_js) && $eplug_js) {
|
|
echo "\n<!-- eplug_js -->\n";
|
|
echo "<script type='text/javascript' src='{$eplug_js}'></script>\n";
|
|
}
|
|
if (isset($htmlarea_js) && $htmlarea_js) {
|
|
echo $htmlarea_js;
|
|
}
|
|
if ((strpos(e_SELF, 'fileinspector.php') === FALSE) && getperms("0"))
|
|
{
|
|
echo "<script type='text/javascript'>
|
|
<!--
|
|
function savepreset(ps,pid){
|
|
if(confirm('".$tp->toJS(LAN_PRESET_CONFIRMSAVE)."'))
|
|
{
|
|
document.getElementById(ps).action='".e_SELF."?savepreset.'+pid;
|
|
document.getElementById(ps).submit();
|
|
}
|
|
}
|
|
//-->
|
|
</script>\n";
|
|
}
|
|
|
|
if (function_exists('headerjs')){echo headerjs(); }
|
|
|
|
//
|
|
// E: Send CSS
|
|
//
|
|
echo "<!-- *CSS* -->\n";
|
|
|
|
if (isset($eplug_css) && $eplug_css) {
|
|
echo "\n<!-- eplug_css -->\n";
|
|
echo "<link rel='stylesheet' href='{$eplug_css}' type='text/css' />\n";
|
|
}
|
|
|
|
echo "<!-- Theme css -->\n";
|
|
if (strpos(e_SELF.'?'.e_QUERY, 'menus.php?configure') === FALSE && isset($pref['admincss']) && $pref['admincss'] && file_exists(THEME.$pref['admincss'])) {
|
|
$css_file = file_exists(THEME.'admin_'.$pref['admincss']) ? THEME_ABS.'admin_'.$pref['admincss'] : THEME_ABS.$pref['admincss'];
|
|
echo "<link rel='stylesheet' href='".$css_file."' type='text/css' />\n";
|
|
} else if (isset($pref['themecss']) && $pref['themecss'] && file_exists(THEME.$pref['themecss']))
|
|
{
|
|
$css_file = file_exists(THEME.'admin_'.$pref['themecss']) ? THEME_ABS.'admin_'.$pref['themecss'] : THEME_ABS.$pref['themecss'];
|
|
echo "<link rel='stylesheet' href='".$css_file."' type='text/css' />\n";
|
|
|
|
|
|
}
|
|
else
|
|
{
|
|
$css_file = file_exists(THEME.'admin_style.css') ? THEME_ABS.'admin_style.css' : THEME_ABS.'style.css';
|
|
echo "<link rel='stylesheet' href='".$css_file."' type='text/css' />\n";
|
|
}
|
|
if (!isset($no_core_css) || !$no_core_css) {
|
|
echo "<link rel='stylesheet' href='".e_FILE_ABS."e107.css' type='text/css' />\n";
|
|
}
|
|
|
|
|
|
//
|
|
// F: Send Meta Tags and Icon links
|
|
//
|
|
echo "<!-- *META* -->\n";
|
|
|
|
// Multi-Language meta-tags with merge and override option.
|
|
|
|
echo "<meta http-equiv='content-type' content='text/html; charset=".CHARSET."' />
|
|
<meta http-equiv='content-style-type' content='text/css' />\n";
|
|
|
|
// --- Load plugin Meta files and eplug_ before others --------
|
|
if (is_array($pref['e_meta_list']))
|
|
{
|
|
foreach($pref['e_meta_list'] as $val)
|
|
{
|
|
if(is_readable(e_PLUGIN.$val."/e_meta.php"))
|
|
{
|
|
echo "<!-- $val meta -->\n";
|
|
require_once(e_PLUGIN.$val."/e_meta.php");
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
// ---------- Favicon ---------
|
|
if (file_exists(THEME."favicon.ico")) {
|
|
echo "<link rel='icon' href='".THEME_ABS."favicon.ico' type='image/x-icon' />\n<link rel='shortcut icon' href='".THEME_ABS."favicon.ico' type='image/xicon' />\n";
|
|
}elseif (file_exists(e_BASE."favicon.ico")) {
|
|
echo "<link rel='icon' href='".SITEURL."favicon.ico' type='image/x-icon' />\n<link rel='shortcut icon' href='".SITEURL."favicon.ico' type='image/xicon' />\n";
|
|
}
|
|
|
|
//
|
|
// G: Send Theme Headers
|
|
//
|
|
|
|
|
|
if(function_exists('theme_head')){
|
|
echo "\n<!-- *THEME HEAD* -->\n";
|
|
echo theme_head();
|
|
}
|
|
|
|
|
|
//
|
|
// H: Generate JS for image preloads [user mode only]
|
|
//
|
|
echo "\n<!-- *PRELOAD* -->\n";
|
|
|
|
//
|
|
// I: Calculate JS onload() functions for the BODY tag [user mode only]
|
|
//
|
|
$body_onload = "";
|
|
|
|
|
|
//
|
|
// J: Send end of <head> and start of <body>
|
|
//
|
|
echo "</head>
|
|
<body".$body_onload.">\n";
|
|
$sql->db_Mark_Time("End Head, Start Body");
|
|
|
|
//
|
|
// K: (The rest is ignored for popups, which have no menus)
|
|
//
|
|
|
|
// require $e107_popup =1; to use it as header for popup without menus
|
|
if(!isset($e107_popup))
|
|
{
|
|
$e107_popup = 0;
|
|
}
|
|
if ($e107_popup != 1) {
|
|
|
|
|
|
//
|
|
// L: (optional) Body JS to disable right clicks [reserved; user mode]
|
|
//
|
|
|
|
//
|
|
// M: Send top of body for custom pages and for news [user mode only]
|
|
//
|
|
|
|
//
|
|
// N: Send other top-of-body HTML
|
|
//
|
|
|
|
$ns = new e107table;
|
|
$e107_var = array();
|
|
|
|
if (!function_exists('show_admin_menu')) {
|
|
function show_admin_menu($title, $active_page, $e107_vars, $js = FALSE, $sub_link = FALSE, $sortlist = FALSE) {
|
|
global $ns, $BUTTON, $BUTTON_OVER, $BUTTONS_START, $BUTTONS_END, $SUB_BUTTON, $SUB_BUTTON_OVER, $SUB_BUTTONS_START, $SUB_BUTTONS_END;
|
|
$id_title = "yop_".str_replace(" ", "", $title);
|
|
if (!isset($BUTTONS_START)) {
|
|
$BUTTONS_START = "<div style='text-align:center; width:100%'><table class='fborder' style='width:98%;'>\n";
|
|
}
|
|
if (!isset($BUTTON)) {
|
|
$BUTTON = "<tr><td class='button'><div style='width:100%; text-align:center'><a style='cursor:pointer; text-decoration:none;' {ONCLICK} >{LINK_TEXT}</a></div></td></tr>\n";
|
|
}
|
|
if (!isset($BUTTON_OVER)) {
|
|
$BUTTON_OVER = "<tr><td class='button'><div style='width:100%; text-align:center'><a style='cursor:pointer; text-decoration:none;' {ONCLICK} ><b>« {LINK_TEXT} »</b></a></div></td></tr>\n";
|
|
}
|
|
if (!isset($BUTTONS_END)) {
|
|
$BUTTONS_END = "</table></div>\n";
|
|
}
|
|
if (!isset($SUB_BUTTON)) {
|
|
$SUB_BUTTON = "<a style='text-decoration:none;' href='{LINK_URL}'>{LINK_TEXT}</a><br />";
|
|
}
|
|
if (!isset($SUB_BUTTON_OVER)) {
|
|
$SUB_BUTTON_OVER = "<b> « <a style='text-decoration:none;' href='{LINK_URL}'>{LINK_TEXT}</a> » </b><br />";
|
|
}
|
|
if (!isset($SUB_BUTTONS_START)) {
|
|
$SUB_BUTTONS_START = "<div style='text-align:center; width:100%'><table class='fborder' style='width:98%;'>
|
|
<tr><td class='button'><a style='text-align:center; cursor:pointer; text-decoration:none;'
|
|
onclick=\"expandit('{SUB_HEAD_ID}');\" >{SUB_HEAD}</a></td></tr>
|
|
<tr id='{SUB_HEAD_ID}' style='display: none' ><td class='forumheader3' style='text-align:left;'>";
|
|
}
|
|
if (!isset($SUB_BUTTONS_END)) {
|
|
$SUB_BUTTONS_END = "</td></tr></table></div>";
|
|
}
|
|
|
|
if ($sortlist == TRUE) {
|
|
$temp = $e107_vars;
|
|
unset($e107_vars);
|
|
foreach (array_keys($temp) as $key) {
|
|
$func_list[] = $temp[$key]['text'];
|
|
}
|
|
|
|
usort($func_list, 'strcoll');
|
|
|
|
foreach ($func_list as $func_text) {
|
|
foreach (array_keys($temp) as $key) {
|
|
if ($temp[$key]['text'] == $func_text) {
|
|
$e107_vars[] = $temp[$key];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$search[0] = "/\{LINK_TEXT\}(.*?)/si";
|
|
$search[1] = "/\{LINK_URL\}(.*?)/si";
|
|
$search[2] = "/\{ONCLICK\}(.*?)/si";
|
|
$search[3] = "/\{SUB_HEAD\}(.*?)/si";
|
|
$search[4] = "/\{SUB_HEAD_ID\}(.*?)/si";
|
|
|
|
if ($sub_link) {
|
|
$replace[0] = '';
|
|
$replace[1] = '';
|
|
$replace[2] = '';
|
|
$replace[3] = $title;
|
|
$replace[4] = $id_title;
|
|
$text = preg_replace($search, $replace, $SUB_BUTTONS_START);
|
|
} else {
|
|
$text = $BUTTONS_START;
|
|
}
|
|
|
|
foreach (array_keys($e107_vars) as $act) {
|
|
if (!isset($e107_vars[$act]['perm']) || !$e107_vars[$act]['perm'] || getperms($e107_vars[$act]['perm'])) {
|
|
if ($active_page == $act || (str_replace("?", "", e_PAGE.e_QUERY) == str_replace("?", "", $act))) {
|
|
$BUTTON_TEMPLATE = $sub_link ? $SUB_BUTTON_OVER : $BUTTON_OVER;
|
|
} else {
|
|
$BUTTON_TEMPLATE = $sub_link ? $SUB_BUTTON : $BUTTON;
|
|
}
|
|
$replace[0] = str_replace(" ", " ", $e107_vars[$act]['text']);
|
|
$replace[1] = $e107_vars[$act]['link'];
|
|
if (!empty($e107_vars[$act]['include'])) {
|
|
$replace[2] = $e107_vars[$act]['include'];
|
|
} else {
|
|
$replace[2] = $js ? "onclick=\"showhideit('".$act."');\"" : "onclick=\"document.location='".$e107_vars[$act]['link']."'; disabled=true;\"";
|
|
}
|
|
$replace[3] = $title;
|
|
$replace[4] = $id_title;
|
|
$text .= preg_replace($search, $replace, $BUTTON_TEMPLATE);
|
|
}
|
|
}
|
|
$text .= $sub_link ? $SUB_BUTTONS_END : $BUTTONS_END;
|
|
|
|
if ($title == "" || $sub_link) {
|
|
return $text;
|
|
} else {
|
|
$ns -> tablerender($title, $text, array('id' => $id_title, 'style' => 'button_menu'));
|
|
}
|
|
}
|
|
}
|
|
|
|
if (file_exists(THEME.'admin_template.php')) {
|
|
require_once(THEME.'admin_template.php');
|
|
} else {
|
|
require_once(e_BASE.$THEMES_DIRECTORY.'templates/admin_template.php');
|
|
}
|
|
|
|
if (!function_exists("parse_admin")) {
|
|
function parse_admin($ADMINLAYOUT) {
|
|
global $tp;
|
|
$adtmp = explode("\n", $ADMINLAYOUT);
|
|
for ($a = 0; $a < count($adtmp); $a++) {
|
|
if (preg_match("/{.+?}/", $adtmp[$a])) {
|
|
echo $tp->parseTemplate($adtmp[$a]);
|
|
} else {
|
|
echo $adtmp[$a];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
function admin_update($update, $type = 'update', $success = false, $failed = false) {
|
|
global $ns;
|
|
if (($type == 'update' && $update) || ($type == 'insert' && $update !== false)) {
|
|
$caption = LAN_UPDATE;
|
|
$text = "<b>".($success ? $success : LAN_UPDATED)."</b>";
|
|
} else if ($type == 'delete' && $update) {
|
|
$caption = LAN_DELETE;
|
|
$text = "<b>".($success ? $success : LAN_DELETED)."</b>";
|
|
} else if (!mysql_errno()) {
|
|
if ($type == 'update') {
|
|
$caption = LAN_UPDATED_FAILED;
|
|
$text = "<b>".LAN_NO_CHANGE."<br />".LAN_TRY_AGAIN."</b>";
|
|
} else if ($type == 'delete') {
|
|
$caption = LAN_DELETE;
|
|
$text = "<b>".LAN_DELETED_FAILED.".<br />".LAN_TRY_AGAIN."</b>";
|
|
}
|
|
} else {
|
|
$caption = LAN_UPDATED_FAILED;
|
|
$text = "<b>".($failed ? $failed : LAN_UPDATED_FAILED." - ".LAN_TRY_AGAIN)."</b><br />".LAN_ERROR." ".mysql_errno().": ".mysql_error();
|
|
}
|
|
$ns -> tablerender($caption, "<div style='text-align:center'>".$text."</div>");
|
|
return $update;
|
|
}
|
|
|
|
function admin_purge_related($table, $id)
|
|
{
|
|
global $ns, $tp;
|
|
$msg = "";
|
|
$tp->parseTemplate("");
|
|
|
|
// Delete any related comments
|
|
require_once(e_HANDLER."comment_class.php");
|
|
$_com = new comment;
|
|
$num = $_com->delete_comments($table, $id);
|
|
if($num)
|
|
{
|
|
$msg .= $num." ".ADLAN_114." ".LAN_DELETED."<br />";
|
|
}
|
|
|
|
// Delete any related ratings
|
|
require_once(e_HANDLER."rate_class.php");
|
|
$_rate = new rater;
|
|
$num = $_rate->delete_ratings($table, $id);
|
|
if($num)
|
|
{
|
|
$msg .= LAN_RATING." ".LAN_DELETED."<br />";
|
|
}
|
|
|
|
if($msg)
|
|
{
|
|
$ns->tablerender(LAN_DELETE, $msg);
|
|
}
|
|
}
|
|
|
|
$sql->db_Mark_Time('Parse Admin Header');
|
|
if (strpos(e_SELF.'?'.e_QUERY, 'menus.php?configure') === FALSE) {
|
|
parse_admin($ADMIN_HEADER);
|
|
}
|
|
$sql->db_Mark_Time('(End: Parse Admin Header)');
|
|
}
|
|
?>
|