X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=inc%2Flibs%2Ftheme_functions.php;h=640dd0b1f3be961dbb33a192acc9fce490a73659;hp=92a2a47ac49e215c9fa14b71f8e864c4acea331f;hb=fad1ea280c27f9ba8ae818b87b0ba29d2c113b1b;hpb=cca98f57dff720b174d21d071cee8303462485d7 diff --git a/inc/libs/theme_functions.php b/inc/libs/theme_functions.php index 92a2a47ac4..640dd0b1f3 100644 --- a/inc/libs/theme_functions.php +++ b/inc/libs/theme_functions.php @@ -10,7 +10,12 @@ * -------------------------------------------------------------------- * * Kurzbeschreibung : Themen-Manager * * -------------------------------------------------------------------- * - * * + * $Revision:: $ * + * $Date:: $ * + * $Tag:: 0.2.1-FINAL $ * + * $Author:: $ * + * Needs to be in all Files and every File needs "svn propset * + * svn:keywords Date Revision" (autoprobset!) at least!!!!!! * * -------------------------------------------------------------------- * * Copyright (c) 2003 - 2008 by Roland Haeder * * For more information visit: http://www.mxchange.org * @@ -37,52 +42,54 @@ if (!defined('__SECURITY')) { require($INC); } -function THEME_SELECTION_BOX($mod, $act, $wht, $result) { +// Create a selection box with installed and activated themes +function THEME_SELECTION_BOX ($mod, $act, $wht, $result) { // Construction URL - $FORM = URL."/modules.php?module=".$mod; - if (!empty($act)) $FORM .= "&action=".$act; - if (!empty($wht)) $FORM .= "&what=".$wht; - define('__FORM_VALUE', $FORM); + $formAction = "{!URL!}/modules.php?module=".$mod; + if (!empty($act)) $formAction .= "&action=".$act; + if (!empty($wht)) $formAction .= "&what=".$wht; // Initialize array - $THEMES = array( + $themesArray = array( 'theme_unix' => array(), // Unix name from filesystem 'theme_name' => array() // Title ); // Load all themes - while(list($theme) = SQL_FETCHROW($result)) { + while ($content = SQL_FETCHARRAY($result)) { // Load it's theme.php file - $INC = sprintf("%stheme/%s/theme.php", PATH, SQL_ESCAPE($theme)); - if (FILE_READABLE($INC)) { + $INC = sprintf("theme/%s/theme.php", SQL_ESCAPE($content['theme_path'])); + if (INCLUDE_READABLE($INC)) { // And save all data in array - require($INC); - $THEMES['theme_unix'][] = $theme; - $THEMES['theme_name'][] = $THEME_NAME; + LOAD_INC($INC); + $themesArray['theme_unix'][] = $content['theme_path']; + $themesArray['theme_name'][] = $GLOBALS['theme_data']['name']; } // END - if } // END - while // Sort whole array by title - array_pk_sort($THEMES, array("theme_name")); + array_pk_sort($themesArray, array("theme_name")); // Construct selection form for the box template $OUT = ""; - foreach ($THEMES['theme_unix'] as $key => $theme) { + foreach ($themesArray['theme_unix'] as $key => $theme) { $OUT .= " \n"; } // END - foreach + // Remember content + $content = array( + 'form_action' => $formAction, + 'selection' => $OUT + ); + // Return generated selection - define('__THEME_SELECTION_OPTIONS', $OUT); - $OUT = LOAD_TEMPLATE("theme_select_form", true); - return $OUT; + return LOAD_TEMPLATE("theme_select_form", true, $content); } // Get version from name function THEME_GET_VERSION ($name) { - global $cacheArray; - // Is the extension "theme" installed? if (!EXT_IS_ACTIVE("theme")) { // Then abort here @@ -93,16 +100,16 @@ function THEME_GET_VERSION ($name) { $cver = "?.?"; // Is the cache entry there? - if (isset($cacheArray['themes']['theme_ver'][$name])) { + if (isset($GLOBALS['cache_array']['themes']['theme_ver'][$name])) { // Get the version from cache - $cver = $cacheArray['themes']['theme_ver'][$name]; + $cver = $GLOBALS['cache_array']['themes']['theme_ver'][$name]; // Count up incrementConfigEntry('cache_hits'); } elseif (GET_EXT_VERSION("cache") != "0.1.8") { // Load version from database - $result = SQL_QUERY_ESC("SELECT theme_ver FROM `{!MYSQL_PREFIX!}_themes` WHERE theme_path='%s' LIMIT 1", - array($name), __FILE__, __LINE__); + $result = SQL_QUERY_ESC("SELECT theme_ver FROM `{!_MYSQL_PREFIX!}_themes` WHERE theme_path='%s' LIMIT 1", + array($name), __FUNCTION__, __LINE__); // Entry found? if (SQL_NUMROWS($result) == 1) { @@ -126,8 +133,6 @@ function THEME_CHECK_EXIST ($name) { // Checks if a theme is active function THEME_IS_ACTIVE ($name) { - global $cacheArray; - // Is the extension "theme" installed? if (!EXT_IS_ACTIVE("theme")) { // Then abort here @@ -138,16 +143,16 @@ function THEME_IS_ACTIVE ($name) { $active = false; // Is the cache entry there? - if (isset($cacheArray['themes']['theme_active'][$name])) { + if (isset($GLOBALS['cache_array']['themes']['theme_active'][$name])) { // Get the version from cache - $active = ($cacheArray['themes']['theme_active'][$name] == "Y"); + $active = ($GLOBALS['cache_array']['themes']['theme_active'][$name] == "Y"); // Count up incrementConfigEntry('cache_hits'); } elseif (GET_EXT_VERSION("cache") != "0.1.8") { // Check if current theme is already imported or not - $result = SQL_QUERY_ESC("SELECT theme_active FROM `{!MYSQL_PREFIX!}_themes` WHERE theme_path='%s' AND theme_active='Y' LIMIT 1", - array($name), __FILE__, __LINE__); + $result = SQL_QUERY_ESC("SELECT theme_active FROM `{!_MYSQL_PREFIX!}_themes` WHERE theme_path='%s' AND theme_active='Y' LIMIT 1", + array($name), __FUNCTION__, __LINE__); // Is the theme active and installed? $active = (SQL_NUMROWS($result) == 1); @@ -162,8 +167,6 @@ function THEME_IS_ACTIVE ($name) { // Gets current human-readable theme name function GET_CURR_THEME_NAME () { - global $cacheArray; - // Is the extension "theme" installed? if (!EXT_IS_ACTIVE("theme")) { // Then abort here @@ -174,16 +177,16 @@ function GET_CURR_THEME_NAME () { $name = GET_CURR_THEME(); // Is the cache entry there? - if (isset($cacheArray['themes']['theme_name'][$name])) { + if (isset($GLOBALS['cache_array']['themes']['theme_name'][$name])) { // Get the version from cache - $name = $cacheArray['themes']['theme_name'][$name]; + $name = $GLOBALS['cache_array']['themes']['theme_name'][$name]; // Count up incrementConfigEntry('cache_hits'); } elseif (GET_EXT_VERSION("cache") != "0.1.8") { // Check if current theme is already imported or not - $result = SQL_QUERY_ESC("SELECT theme_name FROM `{!MYSQL_PREFIX!}_themes` WHERE theme_path='%s' AND theme_active='Y' LIMIT 1", - array($name), __FILE__, __LINE__); + $result = SQL_QUERY_ESC("SELECT theme_name FROM `{!_MYSQL_PREFIX!}_themes` WHERE theme_path='%s' AND theme_active='Y' LIMIT 1", + array($name), __FUNCTION__, __LINE__); // Load theme name list($name) = SQL_FETCHROW($result); @@ -197,20 +200,20 @@ function GET_CURR_THEME_NAME () { } // Initialize variables -$currTheme = GET_CURR_THEME(); +$GLOBALS['curr_theme'] = GET_CURR_THEME(); // Check if new theme is selcted -if ((!empty($_POST['new_theme'])) && ($_POST['new_theme'] != $currTheme)) { +if ((REQUEST_ISSET_POST(('new_theme'))) && (REQUEST_POST('new_theme') != $GLOBALS['curr_theme'])) { // Set new theme for guests - $newTheme = $_POST['new_theme']; + $newTheme = REQUEST_POST('new_theme'); // Change to new theme set_session('mxchange_theme', $newTheme); // Remove current from array and set new - $theme = sprintf("%stheme/%s/theme.php", PATH, $currTheme); - unset($INC_POOL[array_search($theme, $INC_POOL)]); - $INC_POOL[] = sprintf("%stheme/%s/theme.php", PATH, $newTheme); + $theme = sprintf("%stheme/%s/theme.php", constant('PATH'), $GLOBALS['curr_theme']); + REMOVE_INC_FROM_POOL($theme); + ADD_INC_TO_POOL(sprintf("%stheme/%s/theme.php", constant('PATH'), $newTheme)); } // END - if //