]> git.mxchange.org Git - mailer.git/blobdiff - inc/libs/theme_functions.php
fooRequestElementBar() functions renamed, adding of request parameters added:
[mailer.git] / inc / libs / theme_functions.php
index 0c36ae43b923b614be3e21e303ebcc654730685f..4c5c934c98922ae8d90f662c2dd9c319e313af44 100644 (file)
@@ -1,10 +1,10 @@
 <?php
 /************************************************************************
- * MXChange v0.2.1                                    Start: 12/03/2004 *
- * ===============                              Last change: 12/13/2004 *
+ * Mailer v0.2.1-FINAL                                Start: 12/03/2004 *
+ * ===================                          Last change: 12/13/2004 *
  *                                                                      *
  * -------------------------------------------------------------------- *
- * File              : theme-manager.php                                *
+ * File              : theme manager.php                                *
  * -------------------------------------------------------------------- *
  * Short description : Theme manager                                    *
  * -------------------------------------------------------------------- *
@@ -17,7 +17,7 @@
  * 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                           *
+ * Copyright (c) 2003 - 2009 by Roland Haeder                           *
  * For more information visit: http://www.mxchange.org                  *
  *                                                                      *
  * This program is free software; you can redistribute it and/or modify *
 
 // Some security stuff...
 if (!defined('__SECURITY')) {
-       $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), '/inc') + 4) . '/security.php';
-       require($INC);
+       die();
 }
 
 // Create a selection box with installed and activated themes or all if admin
 function generateThemeSelectionBox () {
        // Init variables and fill them if set
-       $what = '';
+       $what = getWhat();
        $mod = getModule();
-       if (isWhatSet()) {
-               $what = getWhat();
-       } // END - if
 
        // Construction URL
-       $formAction = "{?URL?}/modules.php?module=" . $mod;
+       $formAction = "{%url=modules.php?module=" . $mod;
        if (!empty($what)) $formAction .= "&amp;what=" . $what;
+       $formAction = '%}';
 
        // Initialize array
        $themesArray = array(
@@ -65,20 +62,26 @@ function generateThemeSelectionBox () {
        $add = " WHERE `theme_active`='Y'";
 
        // Do we have admin?
-       if (IS_ADMIN()) $add = '';
+       if (isAdmin()) $add = '';
 
        // Select all themes we want
-       $result = SQL_QUERY("SELECT `theme_path`, `theme_name` FROM `{!_MYSQL_PREFIX!}_themes`".$add." ORDER BY `theme_name` ASC", __FILE__, __LINE__);
+       $result = SQL_QUERY("SELECT
+       `theme_path`, `theme_name`
+FROM
+       `{?_MYSQL_PREFIX?}_themes`
+".$add."
+ORDER BY
+       `theme_name` ASC", __FILE__, __LINE__);
 
        // Load all themes
        while ($content = SQL_FETCHARRAY($result)) {
                // Construct relative include file name
-               $INC = sprintf("theme/%s/theme.php", SQL_ESCAPE($content['theme_path']));
+               $inc = sprintf("theme/%s/theme.php", secureString($content['theme_path']));
 
                // Load it's theme.php file if found
-               if (isIncludeReadable($INC)) {
+               if (isIncludeReadable($inc)) {
                        // And save all data in array
-                       loadInclude($INC);
+                       loadInclude($inc);
                        $themesArray['theme_unix'][] = $content['theme_path'];
                        $themesArray['theme_name'][] = $GLOBALS['theme_data']['name'];
                } // END - if
@@ -102,13 +105,13 @@ function generateThemeSelectionBox () {
        );
 
        // Return generated selection
-       return LOAD_TEMPLATE('theme_select_form', true, $content);
+       return loadTemplate('theme_select_form', true, $content);
 }
 
 // Get version from name
-function THEME_GET_VERSION ($name) {
+function getThemeVersion ($name) {
        // Is the extension 'theme' installed?
-       if (!EXT_IS_ACTIVE('theme')) {
+       if (!isExtensionActive('theme')) {
                // Then abort here
                return '!.!';
        } // END - if
@@ -122,10 +125,10 @@ function THEME_GET_VERSION ($name) {
                $cver = $GLOBALS['cache_array']['themes']['theme_ver'][$name];
 
                // Count up
-               incrementConfigEntry('cache_hits');
-       } elseif (GET_EXT_VERSION('cache') != '0.1.8') {
+               incrementStatsEntry('cache_hits');
+       } elseif (getExtensionVersion('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",
+               $result = SQL_QUERY_ESC("SELECT `theme_ver` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' LIMIT 1",
                        array($name), __FUNCTION__, __LINE__);
 
                // Entry found?
@@ -145,13 +148,13 @@ function THEME_GET_VERSION ($name) {
 // Checks wether a theme is found in db
 function ifThemeExists ($name) {
        // Get theme and is it not nul?
-       return (getThemeId($name) > 0);
+       return ((isExtensionActive('theme')) && (getThemeId($name) > 0));
 }
 
 // Checks if a theme is active
 function isThemeActive ($name) {
        // Is the extension 'theme' installed?
-       if (!EXT_IS_ACTIVE('theme')) {
+       if (!isExtensionActive('theme')) {
                // Then abort here
                return false;
        } // END - if
@@ -165,10 +168,10 @@ function isThemeActive ($name) {
                $active = ($GLOBALS['cache_array']['themes']['theme_active'][$name] == 'Y');
 
                // Count up
-               incrementConfigEntry('cache_hits');
-       } elseif (GET_EXT_VERSION('cache') != '0.1.8') {
+               incrementStatsEntry('cache_hits');
+       } elseif (getExtensionVersion('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",
+               $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?
@@ -185,7 +188,7 @@ function isThemeActive ($name) {
 // Gets current human-readable theme name
 function getCurrentThemeName () {
        // Is the extension 'theme' installed?
-       if (!EXT_IS_ACTIVE('theme')) {
+       if (!isExtensionActive('theme')) {
                // Then abort here
                return 'default';
        } // END - if
@@ -199,10 +202,10 @@ function getCurrentThemeName () {
                $name = $GLOBALS['cache_array']['themes']['theme_name'][$name];
 
                // Count up
-               incrementConfigEntry('cache_hits');
-       } elseif (GET_EXT_VERSION('cache') != '0.1.8') {
+               incrementStatsEntry('cache_hits');
+       } elseif (getExtensionVersion('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",
+               $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
@@ -216,23 +219,120 @@ function getCurrentThemeName () {
        return $name;
 }
 
-// Initialize variables
-$GLOBALS['curr_theme'] = getCurrentTheme();
+// Get current theme name
+function getActualTheme () {
+       // The default theme is 'default'... ;-)
+       $ret = 'default';
+
+       // Load default theme if not empty from configuration
+       if ((isConfigEntrySet('default_theme')) && (getConfig('default_theme') != '')) $ret = getConfig('default_theme');
+
+       if (!isSessionVariableSet('mxchange_theme')) {
+               // Set default theme
+               setTheme($ret);
+       } elseif ((isSessionVariableSet('mxchange_theme')) && (isExtensionInstalledAndNewer('sql_patches', '0.1.4'))) {
+               //die("<pre>".print_r($GLOBALS['cache_array']['themes'], true)."</pre>");
+               // Get theme from cookie
+               $ret = getSession('mxchange_theme');
+
+               // Is it valid?
+               if ((!isExtensionActive('theme')) || (getThemeId($ret) == '0')) {
+                       // Fix it to default
+                       $ret = 'default';
+               } // END - if
+       } elseif ((!isInstalled()) && ((isInstalling()) || (getOutputMode() == true)) && ((isGetRequestParameterSet('theme')) || (isPostRequestParameterSet('theme')))) {
+               // Prepare filename for checking
+               $themeFile = sprintf("theme/%s/theme.php", getRequestParameter('theme'));
+
+               // Installation mode active
+               if ((isGetRequestParameterSet('theme')) && (isIncludeReadable($theme))) {
+                       // Set cookie from URL data
+                       setTheme(getRequestParameter('theme'));
+               } elseif (isIncludeReadable(sprintf("theme/%s/theme.php", secureString(postRequestParameter('theme'))))) {
+                       // Set cookie from posted data
+                       setTheme(secureString(postRequestParameter('theme')));
+               }
+
+               // Set return value
+               $ret = getSession('mxchange_theme');
+       } else {
+               // Invalid design, reset cookie
+               setTheme($ret);
+       }
 
-// Check if new theme is selcted
-if ((REQUEST_ISSET_POST('new_theme')) && (REQUEST_POST('new_theme') != $GLOBALS['curr_theme'])) {
-       // Set new theme for guests
-       $newTheme = REQUEST_POST('new_theme');
+       // Return theme value
+       return $ret;
+}
 
-       // Change to new theme
+// Setter for theme in session
+function setTheme ($newTheme) {
        setSession('mxchange_theme', $newTheme);
+}
+
+// Get id from theme
+function getThemeId ($name) {
+       // Default id
+       $id = '0';
+
+       // Is the cache entry there?
+       if (isset($GLOBALS['cache_array']['themes']['id'][$name])) {
+               // Get the version from cache
+               $id = $GLOBALS['cache_array']['themes']['id'][$name];
+
+               // Count up
+               incrementStatsEntry('cache_hits');
+       } elseif (isExtensionInstalledAndNewer('cache', '0.1.8')) {
+               // Check if current theme is already imported or not
+               $result = SQL_QUERY_ESC("SELECT `id` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' LIMIT 1",
+                       array($name), __FUNCTION__, __LINE__);
 
-       // Remove current from array
-       REMOVE_INC_FROM_POOL(sprintf("theme/%s/theme.php", $GLOBALS['curr_theme']));
+               // Entry found?
+               if (SQL_NUMROWS($result) == 1) {
+                       // Fetch data
+                       list($id) = SQL_FETCHROW($result);
+               } // END - if
 
-       // Add new theme
-       ADD_INC_TO_POOL(sprintf("theme/%s/theme.php", $newTheme));
-} // END - if
+               // Free result
+               SQL_FREERESULT($result);
+       }
+
+       // Return id
+       return $id;
+}
+
+///////////////////////////////////////////////////////////////////////////////
+//                              Only filter functions
+///////////////////////////////////////////////////////////////////////////////
+
+// Filter for generic handling of theme change
+function FILTER_HANDLE_THEME_CHANGE () {
+       // Check if new theme is selcted
+       if ((isPostRequestParameterSet('new_theme')) && (postRequestParameter('new_theme') != getCurrentTheme())) {
+               // Set new theme for guests
+               $newTheme = postRequestParameter('new_theme');
+
+               // Change to new theme
+               setTheme($newTheme);
+
+               // Remove current from array
+               removeIncludeFromPool('theme', sprintf("theme/%s/theme.php", getCurrentTheme()));
+
+               // Add new theme
+               addIncludeToPool('theme', sprintf("theme/%s/theme.php", $newTheme));
+       } // END - if
+}
+
+// Filter for settings theme from user profile, must be executed only if FILTER_FETCH_USER_DATA() ran before
+function FILTER_SET_USERS_THEME () {
+       // Is the user data valid?
+       if (!isMember()) {
+               // Do only run for logged in members
+               debug_report_bug('Please only run this filter for logged in users.');
+       } // END - if
+
+       // Change to new theme
+       setTheme(getUserData('curr_theme'));
+}
 
 // [EOF]
 ?>